Django之Models(三)
Django之Models(三)
创建多对多关系
第一种方式:创建多对多的关系authors=models.ManyToManyField("Author")
class Publisher(models.Model):
name = models.CharField(max_length=30)
city = models.CharField('城市',max_length=60) class Book(models.Model):
name=models.CharField(max_length=20)
price=models.IntegerField()
pub_date=models.DateField()
publisher= models.ForeignKey(Publisher,on_delete=models.SET)
authors=models.ManyToManyField("Author") class Author(models.Model):
name=models.CharField(max_length=32)
address=models.CharField(max_length=32)
第二种方式:手动创建第三张表,不推荐
class Publisher(models.Model):
name = models.CharField(max_length=30)
city = models.CharField('城市',max_length=60) class Book(models.Model):
name=models.CharField(max_length=20)
price=models.IntegerField()
pub_date=models.DateField()
publisher= models.ForeignKey(Publisher,on_delete=models.SET) class Author(models.Model):
name=models.CharField(max_length=32)
address=models.CharField(max_length=32) class Book_Author(models.Model):
book=models.Foreignkey('Book')
author=models.Foreignkey('Author')
补充:
如果想向第三张表插入的方式绑定关系:手动创建第三张表
关联字段
Book_Author.objects.create(book_id=2,authos_id=3) book_obj=Book.objects.get(id=2)
#借助第三张表来查询关联信息
print(book_obj.Book_author_set.all()[0].author) lili出过的书籍名称及价格
第三张表_关联表_字段
Book.objects.filter(book_author_author_name="lili")
绑定多对多关系
book_obj=Book.objects.get(id=2)
authoor_obj=Author.objects.get(id=2)
book_obj.authors.add(author_obj) book_obj=Book.objects.get(id=2)
authoor_objs=Auther.objects.all()
book_obj.authors.add(*author_objs)
解除多对多关系
book_obj=Book.objects.get(id=2)
authoor_objs=Auther.objects.all()
book_obj.authors.remove(*author_objs) book_obj=Book.objects.get(id=2)
authoor_obj=Author.objects.get(id=2)
book_obj.authors.remove(authoor_obj)
查询数据
对象查询: 获取id为3的书籍的作者信息
book_obj=Book.objects.get(id=3)
book_obj.authors.all() 获取id为2的作者写的书的信息
author_obj=Author.objects.get(id=2)
author_obj.book_set.all()
掌握:通过 filter values (双下划线)进行多对多的关联查询
#正向查找(条件)之多对多
ret1=models.Book.objects.filter(name='python').values('author__name')
print(ret1)
ret2=models.Book.objects.filter(author__name="lili").values('name')
print(ret2) #反向查找之多对多:
ret3=models.Author.objects.filter(book__name='python').values('name')
print(ret10)
聚合与分组
聚合 先导入:from django.db.models import Avg,Min,Max,Count ggregate(*args,**kwargs):
通过对QuerySet进行计算,返回一个聚合值的字典。aggregate()中每一个参数都指定一个包含在字典中的返回值。即在查询集上生成聚合。 ret1=Book.object.all().aggregate(Avg('price'))
print(ret1) ret2=ret1=Book.object.all().aggregate(Sum('price'))
print(ret2) Book.objects.filter(authors_name="lili").aggregate(Sum("price")) Book.objects.filter(authors_name="lili").aggregate(lili_money=Sum("price")) Book.objects.filter(authors_name="lili").aggregate(Count('price')) 分组
annotate(*args,**kwargs):
可以通过计算查询结果中每一个对象所关联的对象集合,从而得出总计值(也可以是平均值或总和),即为查询集的每一项生成聚合。 Book.objects.values("authors_name").annotate(Sum("price")) Publish.objects.values('name').annotate(Min("book_price"))
Django之Models(三)的更多相关文章
- Django的Models(三)
ORM操作的一些进阶的方法: ################################################################## # PUBLIC METHODS T ...
- 第三百零九节,Django框架,models.py模块,数据库操作——F和Q()运算符:|或者、&并且——queryset对象序列化
第三百零九节,Django框架,models.py模块,数据库操作——F()和Q()运算符:|或者.&并且 F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from dj ...
- 第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多
第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多.一对一.多对多 链表操作 链表,就是一张表的外键字段,连接另外一张表的主键字段 一对多 models.Forei ...
- 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- 第三百零六节,Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置
Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...
- Django学习(三)---Models(ORM框架)
1) Django 中Models是与数据库相关的,与数据库相关的代码一般写在 models.py中,Django 支持 sqlite3, MySQL, PostgreSQL等数据库,只需要在sett ...
- Django进阶(三)
ORM 众所周知有很多不同的数据库系统,并且其中的大部分系统都包含Python接口,能够让我们更好的利用它们的功能,而这些系统唯一的缺点就是需要你了解SQL,如果你是一个更愿意操纵Python对象,而 ...
- 【Django】--Models 和ORM以及admin配置
Models 数据库的配置 1 django默认支持sqlite,mysql, oracle,postgresql数据库 <1>sqlite django默认使用sqlite的数据库 ...
- 【Python】django模型models的外键关联使用
Python 2.7.10,django 1.8.6 外键关联:http://www.bubuko.com/infodetail-618303.html 字段属性:http://www.cnblogs ...
随机推荐
- Confluence 6 代理和 HTTPS 详细配置指南链接
详细配置指南 更多有关连接器示例,我们提供了一些按步骤配置的指南来帮助你启用 HTTPS 并正确配置你的代理. HTTPS: Running Confluence Over SSL or HTTPS ...
- cf1084d 非常巧妙的树形dp
/* 给定n城市,m条道路,每条路耗油w,每个点有油a[i],从任意点出发,求最大可以剩下的油 dp[i]表示从i开始往下走的最大收益,ans表示最大结果 因为走过的路不能走,所以可以想到最优解肯定经 ...
- Python之argv简明详解
今日看到argv 度娘查找一番,基本都是转载的同一篇文章,总体字数不少但看了之后感觉还是稀里糊涂,自己尝试了一番简单总结如下 当我们需要在命令行执行脚本并需要在执行脚本的同时传入参数给脚本使用,那我们 ...
- linux+jenkins+jmeter+ant持续集成
0.安装jdk 1.下载jdk8 登录网址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151 ...
- linux的systemctl服务及其使用
一.systemd 系统初始化程序,系统开始的第一个进程,PID为1 二.systemctl命令 systemctl list-units ##列出当前系统服务的状态 systemctl lis ...
- Update openssh7.9 on centos6
一.制作RPM安装包1)依赖安装yum install rpm-build gcc make wget openssl-devel krb5-devel pam-devel libX11-devel ...
- 监控宝设置snmp
https://wiki.jiankongbao.com/doku.php/%E6%96%87%E6%A1%A3:snmp%E8%AF%8A%E6%96%AD
- 分享微信h5支付源码
类库代码 wechatH5Pay.php <?php //use Flight; /** * 微信支付服务器端下单 * 微信APP支付文档地址: https://pay.weixin.qq.co ...
- nginx 正则及rewrite常用规则实例
一.正则表达式匹配,其中:* ~ 为区分大小写匹配* ~* 为不区分大小写匹配* !~和!~*分别为区分大小写不匹配及不区分大小写不匹配二.文件及目录匹配,其中:* -f和!-f用来判断是否存在文件* ...
- Codeforces 596D Wilbur and Trees dp (看题解)
一直在考虑, 每一段的贡献, 没想到这个东西能直接dp..因为所有的h都是一样的. #include<bits/stdc++.h> #define LL long long #define ...