models.py:

from django.db import models

# 出版社
class Publisher(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=64, null=False, unique=True) def __str__(self):
return "<Publisher object: {}>".format(self.name) # 书籍
class Book(models.Model):
id = models.AutoField(primary_key=True)
title = models.CharField(max_length=64, null=False, unique=True)
publisher = models.ForeignKey(to="Publisher") def __str__(self):
return "<Book object: {}>".format(self.title)

publisher 中的内容:

book 表中的内容:

正向查询:

基于对象的查询:

orm.py:

import os

if __name__ == '__main__':
# 加载 Django 项目的配置信息
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite2.settings")
# 导入 Django,并启动 Django 项目
import django
django.setup() from app01 import models book_obj = models.Book.objects.first() # 获取第一本书籍对象
ret = book_obj.publisher # 获取第一本书籍关联的出版社
print(ret)
ret_name = book_obj.publisher.name # 获取第一本书籍关联的出版社的 name 字段的内容
print(ret_name)

运行结果:

用下划线进行跨表查询:

orm.py:

import os

if __name__ == '__main__':
# 加载 Django 项目的配置信息
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite2.settings")
# 导入 Django,并启动 Django 项目
import django
django.setup() from app01 import models ret = models.Book.objects.filter(id=1).values_list("publisher__name") # 查询 id 为 1 的出版社的 name 字段
print(ret)

运行结果:

反向查询:

基于对象的查询:

orm.py:

import os

if __name__ == '__main__':
# 加载 Django 项目的配置信息
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite2.settings")
# 导入 Django,并启动 Django 项目
import django
django.setup() from app01 import models publisher_obj = models.Publisher.objects.get(id=2) # 获取 id 为 2 的出版社
ret_book = publisher_obj.book_set.all() # 获取所有该出版社的书籍,book_set 中的 book 是 Book 表的表名小写
ret_titles = ret_book.values_list("title") # 获取第二个出版社的所有书的书名
print(ret_titles)

运行结果:

可以在 Book 类中设置 related_name 来进行别名

修改 models.py 中的 Book 类

# 书籍
class Book(models.Model):
id = models.AutoField(primary_key=True)
title = models.CharField(max_length=64, null=False, unique=True)
publisher = models.ForeignKey(to="Publisher", related_name="aaa") def __str__(self):
return "<Book object: {}>".format(self.title)

related_name 为 aaa,可以把 book_set 替换为 aaa

orm.py:

import os

if __name__ == '__main__':
# 加载 Django 项目的配置信息
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite2.settings")
# 导入 Django,并启动 Django 项目
import django
django.setup() from app01 import models publisher_obj = models.Publisher.objects.get(id=2) # 获取 id 为 2 的出版社
ret_book = publisher_obj.aaa.all() # 获取所有该出版社的书籍,book_set 替换为 aaa
ret_titles = ret_book.values_list("title") # 获取第二个出版社的所有书的书名
print(ret_titles)

运行结果:

用下划线进行跨表查询:

orm.py:

import os

if __name__ == '__main__':
# 加载 Django 项目的配置信息
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite2.settings")
# 导入 Django,并启动 Django 项目
import django
django.setup() from app01 import models ret = models.Publisher.objects.filter(id=2).values_list("book__title") # 获取 id 为 2 的出版社的所有书籍
print(ret)

运行结果:

可以在 Book 类中设置 related_name 来进行别名

修改 models.py 中的 Book 类

# 书籍
class Book(models.Model):
id = models.AutoField(primary_key=True)
title = models.CharField(max_length=64, null=False, unique=True)
publisher = models.ForeignKey(to="Publisher", related_query_name="bbb") def __str__(self):
return "<Book object: {}>".format(self.title)

related_query_name 为 bbb,可以把 values_list 中的 book_title 替换为 bbb_title

orm.py:

import os

if __name__ == '__main__':
# 加载 Django 项目的配置信息
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite2.settings")
# 导入 Django,并启动 Django 项目
import django
django.setup() from app01 import models ret = models.Publisher.objects.filter(id=2).values_list("bbb__title") # 获取 id 为 2 的出版社的所有书籍
print(ret)

运行结果:

最新文章

  1. Update Request
  2. CC1310之使用SMARTRF STUDIO
  3. 用“MEAN”技术栈开发web应用(二)express搭建服务端框架
  4. 分享Kali Linux 2016.2第48周镜像文件
  5. Core Data的简单用法
  6. [ActionScript 3.0] Away3D 天空盒(skybox)例子
  7. [转]UINavigationController 返回的方法汇总
  8. 创业 CEO:如何选择投资人
  9. ViewHolder的作用和用法
  10. ajax无刷新方式收集表单并提交表单
  11. iOS动画开发之五——炫酷的粒子效果
  12. Python逐块读取大文件行数的代码 - 为程序员服务
  13. UML之部署图(Deployment Diagram)
  14. Java集成开发环境--Eclipse for J2EE配置JRE运行环境
  15. 基于libUSB的USB设备固件更新程序(下载数据)(转)
  16. 【java基础】接口VS抽象类
  17. JVM(一) OpenJDK1.8源码在Ubuntu16.04下的编译
  18. 计蒜客NOIP2017提高组模拟赛(五)day2-蚂蚁搬家
  19. SpriteBuilder中节点的%位置移动
  20. [Swift]LeetCode354. 俄罗斯套娃信封问题 | Russian Doll Envelopes

热门文章

  1. npm安装模块没有权限解决办法
  2. 通过类型断言获取error类型,获得更详细的信息
  3. 肤浅的聊聊 TiDB 扫表算子, 扫索引算子, 合取范式(CNF), 析取范式(DNF), skyline pruning
  4. MySQL kill进程后出现killed死锁问题
  5. learning java AWT BoxLayout布局管理器
  6. SDOI R2 咕咕记
  7. 洛谷P2312解方程题解
  8. MySQL 获得 当前日期时间 函数
  9. 【知识点】Java机密
  10. kubernetes 1.14安装部署EFK日志收集系统