今日总结:

多表的增删改查操作

多表操作

book
id title book_detail publish author
onetoone manytoone manytomany

book_obj = models.Book.objects.create(
title='xx',
#book_detail_id = 1,
book_detail = BookDetail(),

)
book_obj.author.add(*[1,2])


book_obj = models.Book.objects.filter(id=2)[0]
book_obj.author.clear()
book_obj.author.remove(*[1,2])
book_obj.author.set([1,2])
models.Book.objects.filter(id=2).delete()


models.Book.objects.filter(id=2).update(
publish_id = 2,
)
book_obj = models.Book.objects.filter(id=2)[0]

book_obj.author.set([1,2])


一对多的基于对象的正反向查询:
查询主键为1的书籍的出版社所在的城市
models.Book.objects.filter(id=1)[0].publish.addr
models.Publish.objects.get(name='18期出版社').book_set.values('title')

一对一的基于对象的正反向查询:
查询一下骚小强的电话
正向
models.Author.objects.get(name='骚小强').au.tel
反向
models.AuthorDetail.objects.get(tel='222').author.name

多对多的基于对象的正反向查询:
水浒传这本书有几个作者参与撰写了

正向:
models.Book.objects.get(title='水浒传').authors.values('name')

反向:
models.Author.objects.get(name='骚小强').book_set.values('title')

一对多的基于双下划线的正反向查询:

查询主键为1的书籍的出版社所在的城市
models.Book.objects.filter(id=1).values('publish__addr')
models.publish.objects.filter(book__id=1).values('addr')
一对一的基于双下划线的正反向查询:
查询一下骚小强的电话
models.Author.objects.filter(name='骚小强').values('au__tel')
models.AuthorDetail.objects.filter(author__name='骚小强').values('tel')

多对多的基于双下划线的正反向查询:

水浒传这本书有几个作者参与撰写了
models.Book.objects.filter(title='水浒传').values('authors__name')
models.Author.objects.filter(book__title='水浒传').values('name')

聚合查询:aggragate()

models.Book.objects.all().aggragate(Avg('price'))

分组: annotate() group by

models.Author.objects.values('id','name').annotate(c=Count('book__id'))

models.Author.objects.filter(Q(age__gt=20)&Q(id__gt=20),name='xxx').annotate(c=Count('book__id')).values('name','c');

1.一对一关系

  models.onetoonefield(to=要关联的表名,to_field='关联的字段')

2.一对多关系

  models.foreignkey(to='要关联的表名',to_field='要关联的字段')

注意:一对一和一对多关系删除时要注意,设置里foreignkey后,要设置级联删除' on_delete=models.CASCADE '

3.多对多关系

  models.manytomanyfield('to'='要关联的表名')

增加:

  pub_obj=models.publish.objects.fillter(id=n)[0]

  多对一插入数据方式1:

    models.book.objects.create(

    title='水浒传',

    publisher=pub_obj,

    )

  多对一插入数据方式2:

    models.book.objects.create(

       title='三国演义',

       publish_id=1,

    )

一对一插入数据方式:

  models.book.objects.create(

  ...,

  ...,

  )

多对多插入数据方式 : 文字描述(首先你要先找到一个具体的对象,然后用这个对象去点那个你要关联的表名,然后点add()把你要插入的东西插入进去 )

  方式一

  #首先先找到一个具体的对象

  book_obj=models.book.objects.get(id=1)

  #

  hh_obj=models.book.objects.get(id=xxx)

  #添加数据

  book_obj.关联的那个表名.add(hh_obj)

  方式二

  book_obj.表名.add(*[1,2])

  book_obj.表名.add(1,2)

一对一

  正向查询: 对象.另一个表名.字段名

  反向查询: 对象.另一个表名.字段名

一对多

  正向查询: 对象.另一个表的表名.字段名

  反向查询: 对象.另一个表的表名_set.all().values(id=xx)

多对多

  正向查询: 对象.另一个表的表名.all()

  反向查询: 对象.另一个表的表秒_set.all()

day056 多表增加和查询的更多相关文章

  1. 巨蟒python全栈开发django7:多表增加和查询

    1.回顾内容&&补充 补充1: 补充2: 这个选择的是第二个解释器. 选择第一个的话,只是针对当前的项目,如果再开新项目的话,需要重新下载安装相关的包. 点击保存,因为我们注释掉了,创 ...

  2. day056-58 django多表增加和查询基于对象和基于双下划线的多表查询聚合 分组查询 自定义标签过滤器 外部调用django环境 事务和锁

    一.多表的创建 from django.db import models # Create your models here. class Author(models.Model): id = mod ...

  3. MyBatis 用户表记录数查询

    搭建MyBatis开发环境,实现用户表记录数查询 1.在MyEclipse中创建工程,导入MyBatis的jar包

  4. 在db2中 两个数据库之间的两个表的联合查询

    大家好,今天遇到了在db2中 两个数据库之间的两个表的联合查询 我知道oracle中有dblink,可是不知到db2的两个数据库联合查询怎么处理我找了类似于比如两个数据库: db1,db2用户名密码s ...

  5. 修改表增加字段默认值default

    对个生产库的表增加1个字段.字段类型是INT型, 表数据有2千万条, alter table table_name add xxoo number(4) default  0 ; 因此 不仅要修改字典 ...

  6. Database学习 - mysql 数据库 多表/复合/子 查询

    多表查询 多表查询,基本规则,通过两表有关联字段的进行条件匹配查询 内连接查询 方式一: SELECT 查看字段名[,查看字段名] FROM 一表名,二表名 WHERE 一/二表.字段 = 一/二表. ...

  7. sqlserver为数据库表增加自增字段

     需求: 数据库为SQLServer.对已有的数据库表customer加一个序号字段,一次性对所有现存客户加上编号,并在新建客户时自动增加一个编号,数值自增1. 解决方法: 1. 复制表结构.把原 ...

  8. 在VS2005编程中,有的时候DataGridView数据源有几个表的联合查询,而系统又有限制为一个表,怎么办?

    在VS2005编程中,有的时候DataGridView数据源有几个表的联合查询,而系统又有限制为一个表,怎么办? 解决方法:在SqlServer的企业管理器里增加一个视图吧!!!!!!!!(从来没用过 ...

  9. MySQL:习题(单表多条件查询二)

    Sutdent表的定义 字段名 字段描述 数据类型 主键 外键 非空 唯一 自增 Id 学号 INT(10) 是 否 是 是 是 Name 姓名 VARCHAR(20) 否 否 是 否 否 Sex 性 ...

随机推荐

  1. lua_call/lua_pcall/xpcall

    vs2013+lua5.3.3 1.涉及函数 主要C函数:lua_call和lua_pcall 主要lua函数xpcall 2.正常使用lua_call ①hello.lua文件内容 function ...

  2. 微信小程序不可操作dom节点

    //根据历史记录快速搜索 fastSearch:function(e){ console.log(e.currentTarget.id) wx.navigateTo({ url: '../search ...

  3. 批标准化 Batch Normalization

    2018-12-05 20:28:15 在机器学习领域有一个很重要的假设,即独立同分布假设,也就是说训练集和测试集是满足相同分布的,这是通过训练数据获得的模型能够在测试集获得好的效果的一个基本保障.而 ...

  4. VS2008版本引入第三方dll无强签名

    sn.exe 和ilasm.exe 是系统自带程序.如果显示无此命令,可以从“我的电脑”直接搜索. 将dll文件放入目录下,用VS开发人员命令执行以下命令即可.(以Interop.Scripting. ...

  5. p2739 Shuttle Puzzle

    观察样例得知就是和离'_'左边最近的'w'交换位置,然后和离'_'右边最近的'b'交换位置,轮流进行. #include <iostream> #include <cstdio> ...

  6. jvm看java.lang.OutOfMemoryError: PermGen space

    异常现象 异常信息如下 java.lang.OutOfMemoryError: PermGen space at java.lang.ClassLoader.defineClass1(Native M ...

  7. 集合 (set)

    set 是一个无序不重复的元素集,集合跟字典是无序的,不支持索引 创建集合: 第一种方式:通过{ }创建 >>> num={1,2,3,4,3,3,1} >>> n ...

  8. Fiddler抓包分析

    在Fiddler的web session界面捕获到的HTTP请求如下图所示:   各字段的详细说明已经解释过,这里不再说明.需要注意的是#号列中的图标,每种图标代表不同的相应类型,具体的类型包括:   ...

  9. Forbidden Subwords

    pro: sol: 建出ac自动机. 一个合法的答案对应一条路径满足从一个scc走到另一个scc的路径. 发现这个题的方案数有可能是无限的. 会在以下两种情况无限: 因此,去掉无限情况后,环只有简单环 ...

  10. Spring AOP实现Mysql数据库主从切换(一主多从)

    设置数据库主从切换的原因:数据库中经常发生的是“读多写少”,这样读操作对数据库压力比较大,通过采用数据库集群方案, 一个数据库是主库,负责写:其他为从库,负责读,从而实现读写分离增大数据库的容错率.  ...