日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Django分組聚合查詢實例分享

瀏覽:194日期:2024-10-09 14:57:53

多表查詢

1. 增刪改

一對多:先一后多,外鍵可以為對象或依賴表的主鍵(publish and book)

publish = Publish.objects.create()Book.objects.create(....publish=publish|publish_id=publish.id)

刪: 默認存在級聯刪除

改: book修改外鍵,外鍵一定存在

多對多:

關系表的獲取(book(主鍵) and author) book.author

增:book.author.add(作者對象們|主鍵們)

刪: clear()清除 remove() 可刪除單個作者

改: set([作者對象們|主鍵們])

2. 查

基于對象,正向找屬性,反向找類名小寫,多條記錄類名小寫_set

book.publish.first().name (book 一定是對象,不是queryset)publish.book_set.first().name

基于雙下劃線:

Book.objects.filter(id=1).values(’publish__name’)[0] (values 查出的也是queryset)publish.values(’book__name’)

今日內容

1. 分組查詢: 聚合結果 group_by()

2. 聚合函數

3. 字段

分組查詢(單獨聚合查詢 and 分組聚合查詢---基于mysql)

Book: id name price publish_date publish

聚合函數可以單獨使用 ---- 整張表是一個大組

select max(price) from book

聚合函數在分組下使用

select max(price) as high_price from book group by publish having high_price > 50;

聚合查詢---基于ORM

聚合函數的使用場景:

單獨使用:不分組,只查聚合結果

分組使用: 按字段分組,可查分組字段與聚合結果

導入聚合函數:

from django.db.models import Avg,Max,Min,Count,Sum

單獨聚合查詢:aggregate (聚集,合集)---不分組

# 語法

# 聚合函數: Max, Min,Sum, Avg, Count

aggregate(別名=聚合函數(’字段‘)

規則:

1. 可以同時對多個字段進行聚合處理: aggregate(name1= , name2= ...)

2. 是QuerySet 對象的方法(all,filter)

3. 返回值為dict類型

4. 在aggregate之前的values操作沒作用,被忽略

例: 所有書中最貴的書的價格

dic = Book.objects.all().aggregate(high_price=max(’price),low_price=min(’price’))

分組聚合查詢: annotate (注釋,做注解) --- 分組

# 語法values(’分組字段’).annotate(別名=聚合函數(‘字段’).filter(聚合別名條件).values(’取分組字段’,’取聚合字段別名’))

規則:

1. values --- annotate 分組組合, values控制分組的字段,annotate控制聚合字段

2. values 可以按多個字段分組values(’字段1‘,’字段2‘)

3. 可以同時對多個字段進行聚合處理 annotate(別名1=max(’price’),別名2=min(’price’))

4. 分組后的filter 代表having判斷,只對聚合字段進行條件判斷,(參數為非聚合或分組進行條件判斷代表where判斷)

5. 取字段值 values() 省略默認取所有分組字段和聚合字段,也可以自己定義(對非分組或非聚合字段,該字段自動被變成分組字段)

# 案例:每個出版社出版的最貴的書的價格高于50元的出版社名與最高價格

# 思路:按出版社分組(從book出發),high_price=max(’price’), filter(high_price__gt=50)

# 每個組的價格最貴的

Book.objects.all().values(’publish__name’).annotate(high_price=max(’price’).filter(high_price__gl=50).values(’publish__name’,’high_price’))

字段屬性

1. null: 默認Fasle(默認字段不能為空) , True 表示字段可為null2. blank: 默認False, True 表示字段可以為空3.choice: 限制了該選項字段值必須是指定的choice 中的一個 (元組套元組)sex = models.SmallIntegerField(choice=((1,’man’),(2,’female’)))obj.get_sex_display()

有choices 這個字段的: 要取得’女‘或’男‘, get_字段名sex_display() --超出失效4. db_column: 自定義字段名db_column=’gender’ 起別名該sex5. db_index : True 設置索引6. default: 字段默認值7. editable: 默認為True, False: 不在 admin 界面顯示8. primary_key : TRUE 為主鍵,9. unique: true 字段值不可重復

字段

1. AutoField(): 默認自增主鍵(primary_key=True)2. BooleanField(): 布爾字段, 對應database tinyint 類型3. CharField(): 字符類型(默認不為空)max_length=20,null=True 可以為空4. DateField(): 年月日auto_now = True 數據別更新就會更新時間auto_now_add = True 數據第一次產生時5. DateTimeField(): 年月日時分秒auto_now = True 數據別更新就會更新時間auto_now_add = True 數據第一次產生時6. DecimalField(): 混合精度的小數類型max_digits = 5, 含小數為的最大位數decimal_places = 2 , 小數位數7. IntegerField(): 整型

不常用字段

關系字段

1. ForeignKey(): 外鍵字段to= 關聯模型類 (一對多)to_file = 關聯字段,省略默認關聯主鍵on_delete (外鍵關聯數據被刪除時的操作)models.CASCADE 級聯刪除modles.PROTECT 拋出異常models.SET_NULL 設置空值modles.SET_DEFAULT 設置默認值models.SET(value) 自定義值related_name 自定義反向查詢的字段名db_constraint=False, 取消關聯,但還可以使用鏈表查詢總結: models.ForeignKey(to=’related class name’, null=True,on_delete=models.SET_NULL,db_constraint=False,related_name=’本類名小寫’)2. OneToOneField(): 一對一字段同外鍵3, ManyToManyField() :多對多關系to = 關聯模型類through=關聯關系類through_fields關聯關系表中(本身字段,關聯字段)

斷開外鍵關聯的ForeignKey使用(一對多,一對一)

# 一對多查詢 ----(publish and book)# 方式一 : 不使用外鍵,在book 中添加 publish_id 屬性# 不在支持Django ORM 鏈表查詢語法

# class Book(models.Model):# name = models.CharField(max_length=20)# publish_id = models.IntegerField(null=True)## class Publish(models.Model):# name = models.CharField(max_length=20)## # 查詢方式:# # 通過第一本書book 找出版社# # id = Book.objects.first().publish_id# # publish = Publish.objects.filter(id=id)[0].name# # print(publish)

方式二:使用外鍵, 用db_constrain=False 字段段開連接# 可以使用Django ORM連表查詢語法class Book(models.Model):name = models.CharField(max_length=20)publish = models.ForeignKey(to=’Publish’,db_constraint=False,null=True,on_delete=models.SET_NULL) # to_field=’id’ 不寫會自動添加

class Publish(models.Model):name = models.CharField(max_length=20)

# 書的出版社 (外鍵方式)# print(Book.objects.first().publish.name)# print(Book.objects.filter(pk=1).values(’publish__name’))

斷開關聯--- 多對多自動創建關系表

# 斷開關聯(db_constraint屬性)的多對多自動創建關系表 (book(外鍵) and author)# 斷開后依然支持Django ORMlianiao 查詢語法# 當新表中無需新加額外字段時, 可以自動創建class MyBook(models.Model):name = models.CharField(max_length=20)# 這里會產生第三張表book_author = models.ManyToManyField(to=’MyAuthor’,db_constraint=False)

class MyAuthor(models.Model):name = models.CharField(max_length=20)

# # 查詢方法# # 多對多(自動創建第三張表): 書的作者# b1 = MyBook.objects.first()# # b1.book_author 這個是關系表# for author in b1.book_author.all():# print(author.name)

# print(MyBook.objects.filter(pk=1).values(’book_author__name’))

斷開關聯 --- 多對多手動創建關系表

# 手動創建關系表的原因: 可以擁有自身字段,可以通過關系表類名直接獲取第三張表

# 手動創建關系表可以讓關系表可以擁有更多的自身的字段,同時通過關系表類名可以直接獲取第三張表’’’# ****# 1、和自動建立關系表類似,依然支持Django ORM連表查詢語法(多對多借助關系表連表查詢)class Book(models.Model):name = models.CharField(max_length=20)class Author(models.Model):name = models.CharField(max_length=20)class Book_Author(models.Model):book = models.ForeignKey(to='Book', null=True, on_delete=models.SET_NULL, db_constraint=False)author = models.ForeignKey(to=’Author’, null=True, on_delete=models.SET_NULL, db_constraint=False)time = models.DateField()’’’

’’’# ****2、手動創建關系表,在關系表中用ForeignKey方式支持基于外鍵關系表的ORM連表查詢,同時明確ManyToManyField字段,所以也支持ORM正向方向連表查詢-- db_constraint=False斷開關聯可以在ForeignKey或ManyToManyField任意一方完成class Book(models.Model):name = models.CharField(max_length=20)# 明確through與through_fields,ManyToManyField才不會自動建立關系表,沒有關聯關系后就不能再使用db_constraint字段屬性author = models.ManyToManyField(to=’Author’, through=’Book_Author’, through_fields=(’book_id’, ’author_id’))class Author(models.Model):name = models.CharField(max_length=20)class Book_Author(models.Model):book = models.ForeignKey(to='Book', null=True, on_delete=models.SET_NULL, db_constraint=False)author = models.ForeignKey(to=’Author’, null=True, on_delete=models.SET_NULL, db_constraint=False)time = models.DateField()’’’# 總結:手動創建第三張表,第三張表的增刪改就采用關系表類名衍生的create|delete|update,就不再擁有add|clear|remove|set(因為關系表擁有自己的字段,這些方法無法直接操作這些字段)

到此這篇關于Django分組聚合查詢實例分享的文章就介紹到這了,更多相關Django分組聚合查詢內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Django
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
激情综合网址| 亚洲一级大片| 国产精品一站二站| 欧美中文日韩| 伊人久久高清| 久久视频国产| 91亚洲人成网污www| 国产欧美日韩亚洲一区二区三区| 7m精品国产导航在线| 视频一区二区三区入口| 99pao成人国产永久免费视频| 蜜桃视频在线网站| 九九久久国产| 成人国产精品一区二区网站| 国产精品久久777777毛茸茸| 国产乱人伦精品一区| 日本免费一区二区视频| 亚洲精品一级| 日韩不卡手机在线v区| 国产精品一国产精品| 高清久久精品| 欧美亚洲综合视频| 7m精品国产导航在线| 一区在线观看| 久久久国产精品入口麻豆| 欧美国产日本| 国产精品久久久免费| 欧美专区一区| 国产aa精品| 福利在线一区| 婷婷丁香综合| 亚洲男女自偷自拍| 日韩中文在线电影| 精品国模一区二区三区| 欧美羞羞视频| 首页国产欧美久久| 亚洲欧美网站在线观看| 在线看片一区| 三级久久三级久久久| 日本午夜精品视频在线观看| 成午夜精品一区二区三区软件| 日韩中文字幕高清在线观看| 中文字幕av一区二区三区人| 欧美日韩中出| 国产精品美女在线观看直播| 中文一区一区三区高中清不卡免费| 国产美女高潮在线| 99国产精品视频免费观看一公开| 91高清一区| 日韩中文字幕av电影| 日韩在线观看中文字幕| 国产日韩欧美一区二区三区| 欧美sm一区| 蜜桃伊人久久| 日韩高清二区| 日韩高清成人| 国产亚洲毛片| 日韩精品午夜视频| 韩国一区二区三区视频| 国产精品婷婷| 7m精品国产导航在线| 欧美偷窥清纯综合图区| 麻豆精品久久久| 成人一区不卡| 久久精品一区二区不卡| 亚洲综合中文| 精品亚洲自拍| 久久高清免费| 老鸭窝毛片一区二区三区| 国产精品中文| 爽好多水快深点欧美视频| 免费视频一区二区三区在线观看| 亚洲手机视频| 88久久精品| 岛国av在线网站| 夜夜嗨一区二区| 国产欧美日韩精品高清二区综合区| 欧美91福利在线观看| 日韩欧美2区| 激情综合网五月| 欧美一区激情| 日韩视频久久| 精品中国亚洲| 老色鬼久久亚洲一区二区| 国产 日韩 欧美一区| 日本成人中文字幕在线视频| 欧美 日韩 国产精品免费观看| 日韩精品视频在线看| 婷婷综合亚洲| 国产高清亚洲| 日韩中文欧美| 欧美激情日韩| 老牛国产精品一区的观看方式| 日韩在线精品| 亚洲乱亚洲高清| 五月精品视频| 成人污污视频| 日韩精品久久久久久久软件91| 91久久国产| 日本一区二区免费高清| 国产日韩欧美中文在线| 免费视频久久| 日韩一区二区久久| 风间由美中文字幕在线看视频国产欧美| 三级欧美在线一区| 午夜精品久久久久久久久久蜜桃| 深夜福利亚洲| 噜噜噜久久亚洲精品国产品小说| 中文字幕在线看片| 国产精品成人一区二区网站软件| 亚洲资源av| yellow在线观看网址| 日本在线观看不卡视频| 国产真实久久| 在线 亚洲欧美在线综合一区| 欧美国产偷国产精品三区| 国产亚洲精品精品国产亚洲综合| 亚洲美女久久| 亚洲一级在线| 亚洲欧美日本日韩| 美女少妇全过程你懂的久久| 久久久久亚洲| 精品国产精品国产偷麻豆| 久久国内精品自在自线400部| 欧美精品羞羞答答| 黄色精品视频| 日本久久黄色| 欧美国产极品| 老司机免费视频一区二区| 日韩精品久久久久久久软件91| 亚洲18在线| 日韩中文字幕1| 亚洲日本欧美| 丝袜国产日韩另类美女| 亚洲一区中文| 尤物在线精品| 国产99在线| 99精品视频在线| 久久青青视频| 香蕉视频亚洲一级| www.51av欧美视频| 亲子伦视频一区二区三区| 成人一二三区| 99久久久久国产精品| 亚洲www啪成人一区二区| 欧美一区二区性| 激情久久五月| 亚洲+小说+欧美+激情+另类| 日韩中文字幕av电影| 日韩一二三区在线观看| 日本不卡视频一二三区| 亚洲欧洲午夜| 日本一不卡视频| 日韩1区2区日韩1区2区| 欧美日韩亚洲一区三区| 欧美日韩一区二区三区不卡视频 | 蜜桃久久久久久| 蜜乳av另类精品一区二区| 日韩精品一区二区三区中文在线| 日本在线视频一区二区| 久久在线91| 岛国av在线网站| 中文亚洲欧美| 亚洲精品国产精品粉嫩| 精品一区二区男人吃奶| 欧美好骚综合网| 91久久久久| 视频一区中文字幕| 日韩伦理福利| 亚洲在线网站| 亚洲资源av| 国产探花在线精品一区二区| 欧美激情综合| 亚洲精品一二三区区别| 久久国产精品毛片| 久久的色偷偷| 日韩在线观看| 亚洲综合专区| 国产精品一国产精品| 免费一二一二在线视频| 精品在线91| 国产精品久久| 麻豆视频在线看| 每日更新成人在线视频| 91亚洲无吗| 欧美久久一区二区三区| 精品国产精品久久一区免费式 | 久久国产人妖系列| 成人福利一区 | 日韩欧美少妇| 麻豆91精品| 国产在线一区不卡| 欧美69视频| 国产一区久久| 清纯唯美亚洲综合一区| 精品视频91| 久久久天天操| 激情欧美丁香| 国产精品igao视频网网址不卡日韩 | 在线日韩视频|