DRF如何序列化外键的字段

我觉得在有些应用场景下,这个操作是有用的,因为可以减少一个AJAX的请求,以增加性能。

当然,是二次请求,还是一次传输。这即要考虑用户体验,还要兼顾服务器性能。

一切是有条件的平衡吧。就算是一次传输,字段少的可以全部传,而字段多的就要自定义啦。

在以下样例里,发布单是主表,但相关的项目,组件,用户,如果默认情况下,只显示ID,很不友好。

我们可以将相关的外键名称也一并序列化啦。

 

 

重点的DRF:

class UserSerializer(serializers.ModelSerializer):

    class Meta:
        model = User
        fields = ('id', 'username', 'email', 'first_name', 'last_name', 'is_superuser')

class SiteSerializer(serializers.ModelSerializer):

    class Meta:
        model = Site
        fields = ('id',  'name')

class AppSerializer(serializers.ModelSerializer):

    class Meta:
        model = App
        fields = ('id', 'name')

class DeployPoolSerializer(serializers.ModelSerializer):
    site = SiteSerializer(source='site_name') #如有问题,记得那个read_only,many之类的参数,然后看官方文档
    app = SiteSerializer(source='app_name')
    create_user = UserSerializer()

    class Meta:
        model = DeployPool
        fields = ('id',  'name', 'description', 'site', 'app', 'branch_build',
                  'jira_issue_no', 'create_user', 'change_date')
        read_only_fields = ('name',)

  

 

angular服务和控制器:

prismVersion.factory("versionSrv", ['$resource', function ($resource) {
    return $resource(
        "http://127.0.0.1:8000/server_api/version_api/:Id",
        {Id: "@Id" },
        {'query': {method: 'GET' }},
        {update: {method: "PUT"}}
    );
}]);

prismVersion.factory("siteSrv", ['$resource', function ($resource) {
    return $resource(
        "http://127.0.0.1:8000/server_api/site_api/:Id",
        {Id: "@Id" },
        {'query': {method: 'GET' }},
        {update: {method: "PUT"}}
    );
}]);

prismVersion.controller('versionCtrl',
    ['$scope','versionSrv','siteSrv',
        function($scope,
            versionSrv, siteSrv){
                $scope.versions = versionSrv.query();
}]);

 

angular显示:

<tr ng-repeat="item in versions.results">
                                <td>
                                    <a href="#" target="_blank">{{item.id}}-{{item.name}}</a>

                                </td>

                                <td>
                                    <a href="#">
                                        {{item.app.id}}-
                                        {{item.app.name}}
                                    </a>

                                </td>
                                <td>
                                    <a href="#">
                                        {{item.site.id}}-
                                        {{item.site.name}}
                                    </a>
                                </td>
                                <td>
                                    {{item.branch_build}}
                                </td>

                                 <td>
                                        <a href="#">
                                         {{item.jira_issue_version}}
                                     </a>
                                </td>
                                <td>
                                    {{item.create_user.id}}-
                                    {{item.create_user.username}}
                                </td>

                                <td>
                                    {{item.change_date}}
                                </td>
                            </tr>

  LOOK:

时间: 2024-08-02 06:46:07

DRF如何序列化外键的字段的相关文章

code frist 对于有外键的字段,怎么才能获取到值

问题描述 //信息表publicclassNewsInfo{[Key]publicintNewsID{get;set;}[Required][MaxLength(100)]publicstringNewsMainTitle{get;set;}[Required][MaxLength(100)]publicstringNewsSubTitle{get;set;}[Required]publicNewsCategoryNewsCategory{get;set;}publicstringNewsWor

个人总结的mysql、sqlserver、oracle维护索引、外键、字段、表语法

1.     MYSQL数据库 1)    创建索引 CREATE INDEX index_name ON table_name(column_list) CREATE UNIQUE INDEX index_name ON table_name(column_list) 修改表的方式添加索引 ALTER TABLE table_name ADD INDEX index_name(column_list) ALTER TABLE table_name ADD UNIQUE (column_list

django rest framework如何实现nest field显示,如何保存有外键的字段更新

一步一步深入了. 相关设置技巧如下: 直接nest field显示: class VersionPoolSerializer(serializers.ModelSerializer): site_name = serializers.ReadOnlyField(source='site_name.name') dep_version = DeployPoolSerializer(many=True, required=False, read_only=True) create_user = se

MS SQL巡检系列&amp;mdash;&amp;mdash;检查外键字段是否缺少索引

前言感想:一时兴起,突然想写一个关于MS SQL的巡检系列方面的文章,因为我觉得这方面的知识分享是有价值,也是非常有意义的.一方面,很多经验不足的人,对于巡检有点茫然,不知道要从哪些方面巡检,另外一方面,网上关于MS SQL巡检方面的资料好像也不是特别多.写这个系列只是一个分享,自己的初衷是一个知识梳理.总结提炼过程,有些知识和脚本也不是原创,文章很多地方融入了自己的一些想法和见解的,不足和肤浅之处肯定也非常多,抛砖引玉,也希望大家提意见和建议.补充,指正其中的不足之处.Stay Hungry

SQL Server 2008可视化设置外键的操作

环境:SQL Server 2008 问题:可视化设置外键 解决:table->选中表->design->选中需要设置外键的字段->选择"关系"->选择"添加"->在表和列规范处选择右边省略号(见图一)->再选择相应关系(见图二). 图一: 图二:

【hibernate框架】关系映射之一对一单项外键关联(Annotation实现)

一对一单向外键关联(Annotation做法): 例子,假设一夫配一妻(Husband与Wife).两个实体类的例子: Husband.java: package cn.edu.hpu.one2one; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.OneToOne; @Entity pu

【hibernate框架】关系映射之一对一单向外键关联(XML实现)

在XML里面如何单向关联: 学生证与学生卡是一对一的关系,在学生证那一方做关联 Student.java: package cn.edu.hpu.model; public class Student { private int id; private String name; private int age; public int getId() { return id; } public void setId(int id) { this.id = id; } public String g

跪求大虾。 解决小问题。 关于一个主外键修改问题。。

问题描述 我想修改主表中的一个字段.也就是外键.我实现的SQL语句是这样的updateCardsetCardTypeId=@CardTypeId,CardNo=@cardNo,CardPassword=@CardPassword,CardDesc=@CardDesc,CardState=@CardStatewhereCardId=@cardIdi=DBHelper.ExecuteCommand(sql,newSqlParameter("@CardTypeId",card.CardTyp

MYSQL外键约束的学习笔记

在项目中,很多时候我们建数据表单的时候,两个表示相关联的,并且一个表里面的数据是完全依赖另一张表的数据的, 外键约束语法 [CONSTRAINT [symbol]] FOREIGN KEY     [index_name] (index_col_name, ...)     REFERENCES tbl_name (index_col_name,...)     [ON DELETE reference_option]     [ON UPDATE reference_option] refer