Django 关联模型和关联查询

了解前提:模型的查询对象

三种模型

一对一模型:关系字段定义在任意一端中
一对多模型:关系字段定义在多的一端中;一对多中,外键对应的是主表的一个对象,而不是一个单纯的id

多对多模型:自动生成第三张表,第三张表为关系表;先实例化对象添加两张表,然后再添加关系

在模型中建立以下关联字段

建立各种关系参考

 定义模型关系和关联字段
 #学生表与班级是一对多
    g = models.ForeignKey(to="Grade", to_field="Grade_id")

 #学生信息表与学生表一对一
    stu = models.OneToOneField(to="Student", to_field="Student_id")

 #课程表与学生表是多对多
    stu = models.ManyToManyField(to="Student", to_field="Student_id")

关联查询进行:

一对一操作关联查询:
前提: 由学生信息表Student 查询学生详情表 StudentDetail ,
Student 定义: detail = models.OneToOneField("StudentDetail", to_field="id")

正向查询
stu = models.Student.objects.first()
stu.detail.email  // 基于学生表detail关联字段的关连查询StudentDetail的email  
'1@qq'

反向查询(由学生详情表反向查询学生信息表)
detail = models.StudentDetail.objects.get(id=1)
detail.student.sname  // 基于student字段的关连查询student的sname  
一对多关联查询:
前提: 由学生信息表Student 查询班级表 Class,
cid = models.ForeignKey(to="Class", to_field="id")

正向查询
stu = models.Student.objects.first()
stu.cid.cname // 基于学生表Student关联字段cid关连查询Class的cname 

反向查询
cls = models.Class.objects.first()
cls.student_set.all() //通过_set魔术方法调用的方式来查询学生表中关联信息

注意:
_set:提供了对象访问相关联表数据的方法。但这种方法只能是相关类访问定义了关系的类(主键类访问外键类)。
如果不在外键的字段中设置related_name的话,默认就用表名_set。
如果设置了related_name=”students”,反向查询时可直接使用students进行反向查询。

多对多操作
前提: 由老师表Teacher查询班级表 Class, 建立关系表Teacher2Class
cid_tid = models.ManyToManyField(to="Class",
                                   through="Teacher2Class",
                                   through_fields=("tid", "cid"))

正向查询
tea = models.Teacher.objects.first()
tea.cid_tid.all()

反向查询
cls = models.Class.objects.first()
cls..teacher_set.all()
下划线的正确使用

从上面例子, 得出获取对象数据字段时, 单个的数据对象跨表查询可以用点或者set魔术方法。
而QuerySet可以使用双下划线“
_”,例如获取Uhost表中外键关联的project表的project id 和project name,可以这样做:

>>> host2 = Uhost.objects.all().values(‘ip‘,‘name‘,‘project__id‘,‘project__name‘)
>>> host2[0]
{‘ip‘: u‘10.6.13.253‘, ‘project__name‘: u‘CPMS10‘, ‘name‘: u‘dbbackupsyncer2‘, ‘project__id‘: u‘org-81‘}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容