日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ORM 关系对象映射 基础知识点

發布時間:2025/5/22 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ORM 关系对象映射 基础知识点 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
優點:1.ORM使我們通用的數據庫變得更加的簡單便捷。2.可避免新手程序員寫sql語句帶來的性能問題。

?

1. 創建單表
2. 創建關鍵表
1). 一對一
2). 一對多
3). 多對多

?

創建表的語句:

python manage.py makemigrationspython manage.py migrate

?

插入:

Author.object.create(**{'name':'wjw'})

修改:

# 方法一 author = models.Author.objects.get(id=5)author.name = 'haha'author.save()# 方法二models.Author.objects.filter(id=5).update(name='haha')

查詢:

.filter(**kwargs) # 集合 .all() # 集合 .get(**kwargs) # 行對象

排序:

au = models.Author.objects.order_by('-id') .reverse() 對查詢結果反向排序.distinct() 從返回結果中去重 .count() 數量.first() 取第一條.last() 取最后一條.exists() 如果QuerySet中包含數據返回true,否則返回false

?

?

一對多:

創建數據表

class Author(models.Model):name = models.CharField(max_length=32)age = models.IntegerField()class Book(models.Model):author = models.ForeignKey('Author', on_delete=models.CASCADE)namebook = models.CharField(max_length=32)nametype = models.CharField(max_length=32)

正向查詢

  # 正向查詢obj = models.Book.objects.filter(namebook='python')[0]print(obj.author.name)# 連級查詢obj = models.Book.objects.values('namebook', 'author__name')[0]print(obj['namebook'] + "++++" + obj['author__name'])

反向查詢

  # 反向查詢obj = models.Author.objects.filter(name='lixiangshuai')[0]list = obj.book_set.all().values('namebook')print(list)for item in list:print(item['namebook'])

?

多對多:

創建多對多數據表

class Teacher(models.Model):name = models.CharField(max_length=32)sex = models.CharField(max_length=32)class Student(models.Model):name = models.CharField(max_length=32)sex = models.CharField(max_length=32)teacher = models.ManyToManyField('Teacher')

正向查詢

s = models.Student.objects.filter(name='wangjiawei')[0] t = s.teacher.all() for i in t:print(i.name)

反向查詢

t = models.Teacher.objects.get(name='zhangjiong') s = t.student_set.all()
# s = t.student_set.all().values('name') for i in s:
  print(i.name)

?

基于 __ (雙下劃綫)的條件查找:

只適用于單表

id__lt = 10, id__gt = 1 # id>1 并且 id<10 id__in = [11, 22, 33] # id = 11,22,33,的數據 .exclude(id__in=[11, 22, 33]) # not in id__range = [1,2] # 范圍 bettween··· and ··· name__contains = 'ven' name__icontains = 'ven' # icontains 大小寫不敏感 __startwith = 'p' # 開頭是 p

?

聚合查詢

.aggregate(*args, **kwargs) # 平均價格 .aggregate(avarage_price = Avg('price')) >>> {'avarage_price':34.35} Avg 平均值 Min 最小值 Max 最大值 Sum 求和

?

分組查詢

annotate(*args, **kwargs)models.Author.objects.values('author__name').annotate(sum('price'))

?

?

?

完成~!?收工!!~!~!

?

轉載于:https://www.cnblogs.com/wjw1014/p/8671080.html

總結

以上是生活随笔為你收集整理的ORM 关系对象映射 基础知识点的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 88xx成人永久免费观看 | 中文字幕自拍 | 久久久久久无码精品人妻一区二区 | 热九九精品 | 久久久噜噜噜久久 | 天天插天天操天天干 | 性xxxx欧美 | 天天射日 | 性xxxx另类xxⅹ| 欧美日性视频 | 亚洲高清一区二区三区 | 亚洲熟妇av日韩熟妇在线 | 91看视频| 人人看人人爽 | proumb性欧美在线观看 | 欧美xxxx性xxxxx高清 | 热99在线 | 精品一区二区中文字幕 | 中文字幕三区 | 操久久久| www成人免费 | 国产一区,二区 | 中文幕无线码中文字蜜桃 | 男欢女爱久石 | 亚洲人成电影在线 | 国产69视频在线观看 | 色婷婷激情网 | 婷婷影音 | china国产乱xxxxx绿帽 | 亚洲熟妇无码另类久久久 | 色哟哟一区二区 | 久久久久一区二区 | 欧美精品aaa| 喷水在线观看 | 欧美不卡视频 | 在线成人观看 | 欧美尹人| av三级| 亚洲熟妇av乱码在线观看 | 国产精品一区二区黑人巨大 | 草草影院1| 91丨九色丨海角社区 | 久草视频在线免费看 | 久久久夜色 | 丁香综合激情 | 欧美三级韩国三级日本三斤在线观看 | 日韩精品在线视频 | 好吊色网站 | 欧美另类自拍 | 亚洲天堂一区二区 | 999久久久久 | 亚洲精品成人无码熟妇在线 | 欧美成人精品一区二区综合免费 | 亚洲精品中文字幕乱码无线 | 18视频在线观看娇喘 | 操欧洲美女| 久久人妻少妇嫩草av无码专区 | 精品乱码一区二区三区四区 | 97国产精东麻豆人妻电影 | av在线收看 | 米奇久久| 国产无遮挡免费观看视频网站 | 黑人一级女人全片 | 91叼嘿视频| 男人女人拔萝卜视频 | 久草视频中文在线 | 日韩夜夜 | 日韩一二三区在线观看 | 欧美福利影院 | www欧美日韩| 人人搞人人爱 | 日本在线视频播放 | 国产精品字幕 | 欧美成人乱码一区二区三区 | 亚洲va欧美va| 四季av一区二区夜夜嗨 | 国产精品一区在线观看 | 亚洲毛片一区 | 色噜噜一区二区 | 亚洲毛片大全 | 国产人妖视频 | 色黄大色黄女片免费中国 | 成人宗合网 | 亚洲欧美日韩第一页 | 日韩一级伦理片 | 精品少妇一区二区三区在线观看 | 熟女高潮一区二区三区视频 | 男女免费观看视频 | 99资源在线 | 国产亚洲精品久久久久久久 | 日本韩国欧美在线 | 欧美一区亚洲二区 | 色综合自拍 | 成年人香蕉视频 | 亚洲一区91| 欧美黑人啪啪 | 777四色| 亚洲国产精品一区二区久久hs | 91亚色 |