前面一篇在xadmin后台一个页面显示2个关联表(OneToOneField)的字段,使用inlines内联显示。本篇继续学习一对一(OneToOneField)关系的查询。
上一篇list_display只显示了当前表的字段信息,若是想显示关联表的字段,须要关联查询。html
接着前面的一篇python测试开发django-33.admin后台一对一关系OneToOneField,先设计Card和CarDetail表python
# models.py from django.db import models # Create your models here. class Card(models.Model): '''银行卡 基本信息''' card_id = models.CharField(max_length=30, verbose_name="卡号", default="") card_user = models.CharField(max_length=10, verbose_name="姓名", default="") add_time = models.DateField(auto_now=True, verbose_name="添加时间") class Meta: verbose_name_plural = '银行卡帐户' verbose_name = "银行卡帐户_基本信息" def __str__(self): return self.card_id class CardDetail(models.Model): '''银行卡 详情信息''' card = models.OneToOneField(Card, on_delete=models.CASCADE, verbose_name="卡号" ) tel = models.CharField(max_length=30, verbose_name="电话", default="") mail = models.CharField(max_length=30, verbose_name="邮箱", default="") city = models.CharField(max_length=10, verbose_name="城市", default="") address = models.CharField(max_length=30, verbose_name="详细地址", default="") class Meta: verbose_name_plural = '我的资料' verbose_name = "帐户_我的资料" def __str__(self): return self.card.card_user
为了调试方便,能够使用django的shell模式,对表的数据增删改查操做,打开cmd,cd到manage.py目录shell
python manage.py shelldjango
先在Card表新增一条记录:card_id='900100200300400500', card_user='乔峰'ruby
>>> from hello.models import Card,CardDetail >>> c = Card.objects.create(card_id='900100200300400501', card_user='乔峰') >>> c.save <bound method Model.save of <Card: 900100200300400501>> >>>
接着在CardDetail表新增一条关联的信息函数
>>> d = CardDetail.objects.create(card=c, tel='1500012332',mail='12345678@qq.com', city='上海',address='张江高科') >>> d.save <bound method Model.save of <CardDetail: 乔峰>> >>>
接着上面的操做,查询Card表的card_id和card_user字段值学习
>>> c.card_id '900100200300400501' >>> c.card_user '乔峰'
经过Card表对象c查询关联的CardDetail表里面的字段值测试
>>> c.carddetail.tel '1500012332' >>> c.carddetail.mail '12345678@qq.com'
若是是以CardDetail表为操做对象,能够直接查询CardDetail表里面的字段值spa
>>> d.tel '1500012332' >>> d.city
也能够经过CardDetail表为对象,查询关联的Card表的值设计
>>> d.card.card_id '900100200300400501' >>> d.card.card_user '乔峰'
在上一篇【python测试开发django-35.xadmin注册表信息】经过内联(inlines)能够在详情页面显示关联的表信息
若是咱们想让关联表的字段显示在list_display列表界面,这里就须要本身定义函数,经过表的关联去查询了
# adminx.py import xadmin from .models import Card, CardDetail class ControlStudent(object): # 显示的字段 list_display = ('student_id', 'name', 'age', 'score') # 搜索条件 search_fields = ('name',) # 每页显示10条 list_per_page = 10 class MoreInfo(object): model = CardDetail class ControlCard(object): list_display = ["card_id", "card_user", "电话", "城市", "add_time"] # 在Card页面显示更多信息CardDetail inlines = [MoreInfo] # 查询关联表的tel字段 def 电话(self, obj): return obj.carddetail.tel def 城市(self, obj): return obj.carddetail.city # 注册card表,关联CardDetail xadmin.site.register(Card, ControlCard)
此时页面显示效果以下