欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django框架ORM數(shù)據(jù)庫(kù)操作實(shí)例詳解

 更新時(shí)間:2019年11月07日 11:31:51   作者:HMMHMH  
這篇文章主要介紹了Django框架ORM數(shù)據(jù)庫(kù)操作,結(jié)合實(shí)例形式詳細(xì)分析了Django框架ORM數(shù)據(jù)庫(kù)基本增刪改查與相關(guān)函數(shù)使用技巧,需要的朋友可以參考下

本文實(shí)例講述了Django框架ORM數(shù)據(jù)庫(kù)操作。分享給大家供大家參考,具體如下:

測(cè)試數(shù)據(jù):BookInfo表

PeopleInfo表

一.增加

1.save:

對(duì)象 = 模型類(lèi)(
字段名 = 值,
字段名 = 值,
…
)

對(duì)象.save()

例:

>>> book = BookInfo(
...     name='python入門(mén)',
...     pub_date='2010-1-1'
...   )
>>> book.save()
>>> book
<BookInfo: python入門(mén)>

2.create:

模型類(lèi).objects.create(
字段名 = 值,
字段名 = 值,
…
)

例:

>>> PeopleInfo.objects.create(
...     name='itheima',
...     book=book
...   )
<PeopleInfo: itheima>

二.刪除

1.模型類(lèi)對(duì)象delete:

對(duì)象 = 模型類(lèi).objects.get(條件)
對(duì)象.delete()

例:

>>> person = PeopleInfo.objects.get(name='傳智播客')
>>> person.delete()
(1, {'book.PeopleInfo': 1})

2.模型類(lèi).objects.filter().delete():

模型類(lèi).objects.filter(條件).delete()

例:

>>> BookInfo.objects.filter(name='python入門(mén)').delete()
(1, {'book.BookInfo': 1, 'book.PeopleInfo': 0})

三.修改

1.save:

對(duì)象 = 模型類(lèi).objects.get(條件)
對(duì)象.屬性 = 值
對(duì)象.save()

例:

>>> person = PeopleInfo.objects.get(name='itheima')
>>> person.name = 'itcast'
>>> person.save()
>>> person
<PeopleInfo: itcast>

2.update:

模型類(lèi).objects.filter(條件).update(屬性=值) (返回的是受影響的行數(shù))

例:

>>> PeopleInfo.objects.filter(name='itcast').update(name='傳智播客')

四.查詢

1.基本查詢

get:查詢單一結(jié)果,不存在會(huì)拋出DoesNotExist異常。(查詢結(jié)果不是1個(gè)也會(huì)報(bào)錯(cuò))
all:查詢多個(gè)結(jié)果。
count:查詢結(jié)果數(shù)量。

用法:模型類(lèi).objects.get/all/count()

2.過(guò)濾查詢

filter:過(guò)濾出多個(gè)結(jié)果
exclude:排除掉符合條件剩下的結(jié)果
get:過(guò)濾出單一結(jié)果

3.過(guò)濾條件語(yǔ)法

用法:屬性名稱__比較運(yùn)算符 = 值
exact:相等

例:查詢編號(hào)為1的圖書(shū)。

BookInfo.objects.filter(id__exact=1)

可簡(jiǎn)寫(xiě)為:

BookInfo.objects.filter(id=1)

contains:包含

例:查詢書(shū)名包含'傳'的圖書(shū)。

BookInfo.objects.filter(name__contains='傳')
<QuerySet [<BookInfo: 射雕英雄傳>]>

startswith/endswith:以指定值開(kāi)頭/結(jié)尾

例:查詢書(shū)名以'部'結(jié)尾的圖書(shū)

>>> BookInfo.objects.filter(name__endswith='部')
<QuerySet [<BookInfo: 天龍八部>]>

isnull:是否為空

例:查詢書(shū)名為空的圖書(shū)。

>>> BookInfo.objects.filter(name__isnull=True)
<QuerySet []>

in:是否包含在范圍內(nèi)

例:查詢編號(hào)為1或3或5的圖書(shū)

>>> BookInfo.objects.filter(id__in=[1,3,5])
<QuerySet [<BookInfo: 射雕英雄傳>, <BookInfo: 笑傲江湖>]>

gt/gte/lt/lte:比較查詢,分別為大于,大于等于,小于,小于等于

例:查詢編號(hào)大于3的圖書(shū)

>>> BookInfo.objects.filter(id__gt=3)
<QuerySet [<BookInfo: 雪山飛狐>]>

year/month/day/week_day/hour/minute/second:時(shí)間日期

例:查詢1980年發(fā)表的圖書(shū)。

>>> BookInfo.objects.filter(pub_date__year=1980)
<QuerySet [<BookInfo: 射雕英雄傳>]>

4.F對(duì)象和Q對(duì)象

F對(duì)象:用來(lái)比較兩個(gè)屬性(使用前需要導(dǎo)入)
用法:F(屬性名)
例:查詢閱讀量大于等于評(píng)論量的圖書(shū)。

>>> from django.db.models import F
>>> BookInfo.objects.filter(readcount__gt=F('commentcount'))
<QuerySet [<BookInfo: 雪山飛狐>]>

Q對(duì)象:實(shí)現(xiàn)邏輯或or的查詢
用法:Q(屬性名__運(yùn)算符=值),也可在前面加~表示not
例:查詢閱讀量大于20,或編號(hào)小于3的圖書(shū)

>>> BookInfo.objects.filter(Q(readcount__gt=20)|Q(id__lt=3))
<QuerySet [<BookInfo: 射雕英雄傳>, <BookInfo: 天龍八部>, <BookInfo: 雪山飛狐>]>

5.聚合函數(shù)

聚合函數(shù):可使用aggregate()過(guò)濾器調(diào)用聚合函數(shù)(Avg,Count,Max,Min,Sum)
用法:模型類(lèi).objects.aggregate(聚合函數(shù)(字段名))
例:查詢圖書(shū)的總閱讀量。

>>> from django.db.models import Sum
>>> BookInfo.objects.aggregate(Sum('readcount'))
{'readcount__sum': 126}

返回值為字典類(lèi)型:{'屬性名__聚合類(lèi)小寫(xiě)':值}

注意:使用count一般不用使用過(guò)濾器

例:查詢圖書(shū)總數(shù)。

BookInfo.objects.count()

返回值為一個(gè)數(shù)字

6.排序函數(shù)

用法:模型類(lèi).objects.all().order_by(屬性名)
默認(rèn)升序排序,屬性名前加-為降序
例:

# 默認(rèn)升序
>>> BookInfo.objects.all().order_by('readcount')
<QuerySet [<BookInfo: 射雕英雄傳>, <BookInfo: 笑傲江湖>, <BookInfo: 天龍八部>, <BookInfo: 雪山飛狐>]>
# 降序
>>> BookInfo.objects.all().order_by('-readcount')
<QuerySet [<BookInfo: 雪山飛狐>, <BookInfo: 天龍八部>, <BookInfo: 笑傲江湖>, <BookInfo: 射雕英雄傳>]>

7.關(guān)聯(lián)查詢

一到多的訪問(wèn):

用法:一對(duì)應(yīng)的模型類(lèi)對(duì)象.多對(duì)應(yīng)的模型類(lèi)名小寫(xiě)_set
例:查詢id為1的書(shū)籍人物

>>> book = BookInfo.objects.get(id=1)
>>> book.peopleinfo_set.all()
<QuerySet [<PeopleInfo: 郭靖>, <PeopleInfo: 黃蓉>, <PeopleInfo: 黃藥師>, <PeopleInfo: 歐陽(yáng)鋒>, <PeopleInfo: 梅超風(fēng)>]>

多到一的訪問(wèn):

用法:多對(duì)應(yīng)的模型類(lèi)對(duì)象.多對(duì)應(yīng)的模型類(lèi)中的關(guān)系類(lèi).屬性名
例:查詢id為1的人物的書(shū)籍

>>> person = PeopleInfo.objects.get(id=1)
>>> person.book.name
‘射雕英雄傳'

關(guān)聯(lián)過(guò)濾查詢:

用法:關(guān)聯(lián)模型類(lèi)名小寫(xiě)__屬性名__條件運(yùn)算符=值
例:查詢圖書(shū),要求圖書(shū)中人物的描述包含"八"

>>> book = BookInfo.objects.filter(peopleinfo__description__contains='八')
>>> book
<QuerySet [<BookInfo: 射雕英雄傳>, <BookInfo: 天龍八部>]>

查詢圖書(shū)閱讀量大于30的所有人物

>>> people = PeopleInfo.objects.filter(book__readcount__gt=30)
>>> people
<QuerySet [<PeopleInfo: 喬峰>, <PeopleInfo: 段譽(yù)>, <PeopleInfo: 虛竹>, <PeopleInfo: 王語(yǔ)嫣>, <PeopleInfo: 胡斐>, <PeopleInfo: 苗若蘭>, <PeopleInfo: 程靈素>, <PeopleInfo: 袁紫衣>]>

希望本文所述對(duì)大家基于Django的Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論