码迷,mamicode.com
首页 > 其他好文 > 详细

django orm 关联表查询

时间:2016-12-18 02:15:36      阅读:419      评论:0      收藏:0      [点我收藏+]

标签:django orm

django orm 关联表数据,即sql的多表查询

例如两个表:

Apply表中定义了字段positionforeignkey指向job表的id字段,

1.通过job表查找子表apply的字段信息:

    job.objects.values( ‘id‘, ‘job_type‘, ‘apply__date_created‘

 连接符为小写的子表tablename+双下线+子表字段名即:apply__date_created 表示寻找Apply表中的date_created字段

 等价于后台的SQL

 SELECT `job`.`id`, `job`.`job_type`, `apply`.`date_created` FROM`job` LEFT OUTER JOIN `apply` ON ( `job`.`id` = `apply`.`position_id` )

2.filter方法筛选子表字段:

JobInformation.objects.filter(apply__name=’zhang’).values( ‘id‘, ‘job_type‘, ‘apply__date_created‘)

 等价于后台的SQL

SELECT `job`.`id`, `job`.`job_type`,`apply`.`date_created` FROM `job` LEFT OUTER JOIN `apply` ON ( `job`.`id` =`apply`.`position_id` ) where apply.name=’zhang’

3.   再加一个user表,定义jobuser字段foreignkey指向user表的id字段,通过表job查询user表的其他字段,三表查询

Job.objects.filter(apply__name=’zhang’).values( ‘id‘, ‘job_type‘, ‘apply__date_created‘user__address’)

user__address  外键字段名+双下划线+主表字段名

等价于后台的SQL

SELECT `job`.`id`,`job`.`job_type`, `apply`.`date_created`user.address FROM `job` inner JOIN `apply` ON (`job`.`id` = `apply`.`position_id` )  inner  JOINuser on job.user=user.id  where  apply.name=’zhang’


django orm 关联表查询

标签:django orm

原文地址:http://3379770.blog.51cto.com/3369770/1883651

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!