day056 多表增加和查询
今日总结:
多表的增删改查操作
多表操作
增
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 多表增加和查询的更多相关文章
- 巨蟒python全栈开发django7:多表增加和查询
1.回顾内容&&补充 补充1: 补充2: 这个选择的是第二个解释器. 选择第一个的话,只是针对当前的项目,如果再开新项目的话,需要重新下载安装相关的包. 点击保存,因为我们注释掉了,创 ...
- day056-58 django多表增加和查询基于对象和基于双下划线的多表查询聚合 分组查询 自定义标签过滤器 外部调用django环境 事务和锁
一.多表的创建 from django.db import models # Create your models here. class Author(models.Model): id = mod ...
- MyBatis 用户表记录数查询
搭建MyBatis开发环境,实现用户表记录数查询 1.在MyEclipse中创建工程,导入MyBatis的jar包
- 在db2中 两个数据库之间的两个表的联合查询
大家好,今天遇到了在db2中 两个数据库之间的两个表的联合查询 我知道oracle中有dblink,可是不知到db2的两个数据库联合查询怎么处理我找了类似于比如两个数据库: db1,db2用户名密码s ...
- 修改表增加字段默认值default
对个生产库的表增加1个字段.字段类型是INT型, 表数据有2千万条, alter table table_name add xxoo number(4) default 0 ; 因此 不仅要修改字典 ...
- Database学习 - mysql 数据库 多表/复合/子 查询
多表查询 多表查询,基本规则,通过两表有关联字段的进行条件匹配查询 内连接查询 方式一: SELECT 查看字段名[,查看字段名] FROM 一表名,二表名 WHERE 一/二表.字段 = 一/二表. ...
- sqlserver为数据库表增加自增字段
需求: 数据库为SQLServer.对已有的数据库表customer加一个序号字段,一次性对所有现存客户加上编号,并在新建客户时自动增加一个编号,数值自增1. 解决方法: 1. 复制表结构.把原 ...
- 在VS2005编程中,有的时候DataGridView数据源有几个表的联合查询,而系统又有限制为一个表,怎么办?
在VS2005编程中,有的时候DataGridView数据源有几个表的联合查询,而系统又有限制为一个表,怎么办? 解决方法:在SqlServer的企业管理器里增加一个视图吧!!!!!!!!(从来没用过 ...
- MySQL:习题(单表多条件查询二)
Sutdent表的定义 字段名 字段描述 数据类型 主键 外键 非空 唯一 自增 Id 学号 INT(10) 是 否 是 是 是 Name 姓名 VARCHAR(20) 否 否 是 否 否 Sex 性 ...
随机推荐
- css垂直居中方法
CSS垂直居中的简便方法:{position:absolute;left:0;bottom:0;top:0;right:0;margin:auto;}.
- QT文件(夹)操作---QFile、QDir、QFileInfo、QTextStream和QDataStream异同
1.1 文件和目录 QFile.QBuffer和QTcpSocket可支持读写设备,用open函数打开,用write或putChar函数写入.用read和readLine或readAll进行读取 ...
- 第 3 章 镜像 - 017 - RUN vs CMD vs ENTRYPOINT
RUN.CMD 和 ENTRYPOINT 这三个 Dockerfile 指令看上去很类似,很容易混淆. 简单的说: RUN 执行命令并创建新的镜像层,RUN 经常用于安装软件包. CMD 设置容器启动 ...
- 本地广播的简单示例 --Android开发
1.局部通知管理器LocalBroadcastManager,用于同一个应用中不同组件之间发送广播.由于是在同应用中发送广播,所以使用它安全性.效率也会提高. 2.本例实现简单的发送本地广播的案例 点 ...
- docker 基本操作
# 常用命令 docker run 镜像 docker images 查看所有镜像 docke ps 查看运行中的容器 docker ps -a 列出所有容器 docker st ...
- 【洛谷p1507】NASA的食物计划
(一次a……) NASA的食物计划[传送门] 好的上算法标签: 嗯这是个二维背包 (万年不变分隔线) 二维的题就是在一维基础上增加了一个条件,这个背包不仅含有质量还有体积.所以我们增加一层循环.核心算 ...
- 『TensorFlow』第七弹_保存&载入会话_霸王回马
首更: 由于TensorFlow的奇怪形式,所以载入保存的是sess,把会话中当前激活的变量保存下来,所以必须保证(其他网络也要求这个)保存网络和载入网络的结构一致,且变量名称必须一致,这是caffe ...
- Leetcode 1006. 笨阶乘
1006. 笨阶乘 显示英文描述 我的提交返回竞赛 用户通过次数305 用户尝试次数347 通过次数309 提交次数665 题目难度Medium 通常,正整数 n 的阶乘是所有小于或等于 n 的 ...
- 函数使用八:BP_EVENT_RAISE
此函数是关联触发一个已经定义的事件,这个事件可以放到SM36里设置JOB,这样就做成了一个事件触发JOB的东西. Import EVENTID 事件ID ,对应S ...
- docker实战系列之docker 端口映射错误解决方法
错误: Error response from daemon: Cannot start container web: iptables failed: iptables -t nat -A DOCK ...