首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在Django Admin changelist视图中,如何使外键列按主键以外的值排序?

在Django Admin changelist视图中,要使外键列按主键以外的值排序,可以通过自定义模型Admin类的list_display属性来实现。

首先,需要在admin.py文件中导入相关模型和Admin类:

代码语言:txt
复制
from django.contrib import admin
from .models import YourModel

class YourModelAdmin(admin.ModelAdmin):
    list_display = ('id', 'foreign_key_field', 'other_field', ...)  # 按照需要显示的字段顺序设置

admin.site.register(YourModel, YourModelAdmin)

在list_display属性中,按照需要显示的字段顺序设置,其中'foreign_key_field'是外键字段的名称。默认情况下,外键字段会按照外键的主键值进行排序。如果想要按照外键的其他字段进行排序,可以使用双下划线(__)来指定外键的相关字段。

例如,如果外键字段是一个关联到RelatedModel的外键,可以使用'foreign_key_field__related_field'来指定外键的相关字段。在这里,'related_field'是RelatedModel中的一个字段。

示例代码如下:

代码语言:txt
复制
from django.contrib import admin
from .models import YourModel

class YourModelAdmin(admin.ModelAdmin):
    list_display = ('id', 'foreign_key_field__related_field', 'other_field', ...)  # 按照需要显示的字段顺序设置

admin.site.register(YourModel, YourModelAdmin)

这样设置后,外键列将按照指定的外键的相关字段进行排序。

对于Django Admin changelist视图中的其他需求,可以通过自定义模型Admin类的其他属性和方法来实现,例如list_filter、search_fields、actions等。

注意:以上答案中没有提及腾讯云相关产品和产品介绍链接地址,因为该问题与云计算品牌商无关。如有其他问题需要解答,请提供具体内容。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

【Python全栈100天学习笔记】Day41 Django深入理解框架

字段属性primary_key用于设置主键,max_length用来设置字段的最大长度,db_column用来设置数据库中与字段对应的列,verbose_name则设置了Django后台管理系统中该字段显示的名称...使用ORM完成模型的CRUD操作 在了解了Django提供的模型管理平台之后,我们来看看如何从代码层面完成对模型的CRUD(Create / Read / Update / Delete)操作。...db_constraint:是否为外键创建约束,默认值为True。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。...SET_DEFAULT:把外键设置为默认值,提供了默认值才能这么做。 ManyToManyField属性 symmetrical:是否建立对称的多对多关系。

2.3K30
  • Django教程 —— 模型类详解

    引言 在之前的 Django模型设计 中简单的介绍了如何定义模型类,在这篇中将做一个汇总。让大家更加了解Django模型类。...: 当前选择的数据库支持字段的类型 渲染管理表单时使用的默认html控件 在管理站点最低限度的验证 Django 会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后...Django 不会再创建自动增长的主键列。...primary_key 若为True,则该字段会成为模型的主键字段,默认值是False。 unique 如果为True, 这个字段在表中必须有唯一值,默认值是False。...editable bool 类型,在Admin里是否可编辑, help_text 在 Admin 中提示帮助信息 upload_to 指文件上传到哪个位置 null 是数据库范畴的概念,blank 是表单验证范畴的

    1.7K20

    Django模型

    django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...默认创建的主键列属性为id,也可以使用pk,意为primary key. 字段名称中不能出现双下划线,因为这是Django的查询语法之一。...’,在Django3.2之前,默认生成的主键数据类型是AutoField....外键 外键这个东西,通常都是在业务逻辑层面来实现的,而不是在数据库中实现。但是通常大家学习的数据库课程中,都会有数据库设计范式,其中有个第三范式就是专指的外键约束。在这里只是简单的介绍一下。...,此选项会抛出IntegrityError异常 注意:我们在数据库中,设置外键的时候需要制定另一张表中关联的字段,但是在Django里并没有指定。

    1.9K20

    Django 1.10中文文档-第一个应用Part7-自定义管理站点

    Django在admin站点中,自动地将所有的外键关系展示为一个select框。在我们的例子中,目前只有一个question对象存在。 请注意图中的绿色加号,它连接到Question模型。...每一个包含外键关系的对象都会有这个绿色加号。点击它,会弹出一个新增Question的表单,类似Question自己的添加表单。...填入相关信息点击保存后,Django自动将该Question保存在数据库,并作为当前Choice的关联外键对象。通俗讲就是,新建一个Question并作为当前Choice的外键。...如果我们想要同时显示一些别的内容,可以使用list_display属性,它是一个由多个字段组成的元组,其中的每一个字段都会按顺序显示在页面上,代码如下: # polls/admin.py class...你可以点击其中一列的表头来让列表按照这列的值来进行排序,但是was_published_recently这列的表头不行,因为Django不支持按照随便一个方法的输出进行排序。

    3.6K60

    【愚公系列】2022年01月 Python教学课程 40-Django框架之模型属性详解

    2) 关于主键 django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...默认创建的主键列属性为id,可以使用pk代替,pk全拼为primary key。 3) 属性命名限制 不能是python的保留关键字。 不允许使用连续的下划线,这是由django的查询方式决定的。...若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用 unique 如果为True, 这个字段在表中必须有唯一值,默认值是False null是数据库范畴的概念...,blank是表单验证范畴的 6) 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models中包含了可选常量: CASCADE...级联,删除主表数据时连通一起删除外键表中数据 PROTECT保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据 SET_NULL设置为NULL,仅在该字段null=True

    1.4K20

    Django之ORM字段和参数

    ---- BooleanField    布尔值类型,储存布尔值,True或者False ---- EmailField         字符串类型,Django Admin以及ModelForm中提供验证机制...外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。    ...,设置:models.SET(值) 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象) ---- db_constraint    是否在数据库中创建外键约束,默认为True...---- through      在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。...---- ordering     指定默认按什么字段排序。     只有设置了该属性,我们查询到的结果才可以被reverse()。

    2.3K60

    django_mysql_配置

    verbose_name='逻辑删除') class Meta: db_table = 'tb_books' # 指明数据库表名 verbose_name = '图书' # 在admin...2) django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...默认创建的主键列属性为id,可以使用pk代替,pk全拼为primary key。 3) 字段类型 ? 4) 选项 ?...null是数据库范畴的概念,blank是表单验证范畴的 5) 外键 一般我用CASCADE 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models...中包含了可选常量: CASCADE 级联,删除主表数据时连通一起删除外键表中数据 PROTECT 保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据 SET_NULL

    1.6K10

    Mysql基础

    select name from ExamResult where Database is null; -- (4)Order by 指定排序的列,排序的列即可是表中的列名,也可以是select 语句后指定的别名...id INT PRIMARY KEY auto_increment, name VARCHAR (20), charger_id TINYINT, --切记:作为外键一定要和关联主键的数据类型保持一致...语句 --外键约束对子表的含义: 如果在父表中找不到候选键,则不允许在子表上进行insert/update --外键约束对父表的含义: 在父表上进行update/delete以更新或删除在子表中有一条或多条对...-- 应匹配行的候选键时,父表的行为取决于:在定义子表的外键时指定的 -- on update/on delete子句...update/delete记录时,将子表上匹配记录的列设为null -- 要注意子表的外键列不能为not null FOREIGN KEY (charger_id) REFERENCES

    4.2K20

    Django3.2边学边记—Adimn站点管理

    控制显示的列,Django 会尝试按照这个顺序解释 list_display 的每个元素: 一个模型的字段。 一个可调用对象。 一个代表 ModelAdmin 属性的字符串。...def atitle(self):        return self.title 按以上方法显示的列是不能排序的,如果让这个方法显示的列也能排序,就给atitle方法的.admin_order_field...atitle.short_description='标题'   如果是更改模型字段显示的列标题,可以在定义模型字段时,设置verbose_name的值 ,或者封装成方法,再对方法使用上面那个属性,模型字段不能直接使用那个属性...过滤器 用 list_filter 来激活管理更改列表页面右侧侧栏的过滤器,如下截图所示: list_filter 应是一个列表或元组,参数字段可以是模型字段,包括外键字段(注意list_display...是不能直接接收外键字段的),会将对应字段的值列出来,一般用于快速过滤有重复值的字段。

    1.3K30

    Django—入门

    1.定义模型类 模型类定义在models.py文件中,继承自models.Model类。   说明:不需要定义主键列,在生成时会自动添加,并且值为自动增长。...同时我们发现多了一个id项,这一项是Django框架帮我们自动生成的,在创建表的时候id就会作为对应表的主键列,并且主键列自动增长。...在我们之后迁移生成表的时候,Django框架就会自动帮我们在图书表和英雄表之间建立一个外键关系。 最后我们可以看到数据库中生成的英雄表如下图: ?...注意上图中booktest_heroinfo表中有一列hbook_id,这一列名为什么不叫hbook? hbook_id是根据HeroInfo类的关系属性hbook生成的,对应着图书表中的主键id。...上去 6.模板 如何向请求者返回一个漂亮的页面呢? 肯定需要用到html、css,如果想要更炫的效果还要加入js,问题来了,这么一堆字段串全都写到视图中,作为HttpResponse()的参数吗?

    1.9K10

    Django model 层之Models与Mysql数据库小结

    如果修改某个已存在对象,主键列的值,并保存该对象,会在旧对象的基础上,重新构建一个对象。...myapp_album.artist列引用mapp_musician.auto_id字段的值,即mapp_musician.auto_id为myapp_album表的外键。...SET_NULL 删除被参照表的某条表记录,设置参照表中,同待删除记录存在外键关联的记录的外键列值为null。当且仅当设置了null=True选项时可用。...SET_DEFAULT 删除被参照表的某条表记录,设置参照表中,同待删除记录存在外键关联的记录的外键列值为默认值。必须为外键列设置默认值。...SET() 删除被参照表的某条表记录,设置参照表中,同待删除记录存在外键关联关系的记录的外键列值为传递给SET()的参数值,如果传递给SET()的参数值是可调用对象,则设置为调用可调用对象获取的结果。

    2.2K20

    django models.py(python和django)

    verbose_name='描述信息') brand = models.ForeignKey(Brand, on_delete=models.CASCADE, verbose_name='品牌') # 外键...admin.site.register(Brand) admin.site.register(Goods) 1) 数据库表名 模型类如果未指明表名,Django默认以小写app应用名_小写模型类名为数据库表名...2) 关于主键 django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...默认创建的主键列属性为id,可以使用pk代替,pk全拼为primary key。...聚合函数包括:Avg平均,Count数量,Max最大,Min最小,Sum求和 例如:查询所有商品的总数量 2.8mysql中的排序 2.9关联查询 回顾一下表与表的关系,goods表有外键 brand

    1.1K10
    领券