Django數(shù)據(jù)庫(kù)操作

Django是一種Python的Web開發(fā)框架,今天介紹一下數(shù)據(jù)庫(kù)操作.
這里采用sqlite3作為數(shù)據(jù)庫(kù)軟件,因?yàn)樗?del>配置起來(lái)省事輕量,好用.

  1. 構(gòu)建:
    我們首先要在App的models.py中寫入數(shù)據(jù)庫(kù)的定義,但我要講的不是這些,所以請(qǐng)所有不知道的人自己百度,謝謝大家的配合.
    代碼寫完之后,執(zhí)行命令:
python manage.py makemigrations
python manage.py migrate

如果在執(zhí)行第一條命令時(shí)出現(xiàn)問(wèn)題且你不是第一次執(zhí)行這兩條命令,可能是因?yàn)槟阋呀?jīng)生成出的數(shù)據(jù).以刪除api文件夾下所有形如xxxx_initial.py的文件.
如果在執(zhí)行第二條命令時(shí)出現(xiàn)問(wèn)題,可能是因?yàn)槟愕臄?shù)據(jù)庫(kù)已經(jīng)存在相應(yīng)的表,只是你更改了字段后重新生成,這時(shí)你可以將數(shù)據(jù)庫(kù)中的表全部刪掉(如果里面的數(shù)據(jù)重要的話注意保存).然后重新操作即可.
讓我們以這個(gè)表為示例:
Stu:

id name age className
1 小明 10 1
2 小華 11 2
3 小剛 9 3
4 小馬虎 12 2

代碼:

class Stu
    id=models.AutoField(primary_key=True)
    name=models.CharField(max_length=5)
    age=models.IntegerField()
    className=models.IntegerField

2.創(chuàng)建對(duì)象
極簡(jiǎn)方式:

Stu.objects.create(name="小明",age=10,className=1) 

稍微麻煩那么一點(diǎn)點(diǎn)的方式:

stu=Stu(name="小明",age=10,className=1)
stu.save()

再麻煩一點(diǎn)的方式:

stu=Stu()
stu.name="小明"
stu.age=10
stu.className=1
stu.save()

當(dāng)然我們還可以直接用django提供的cursor實(shí)現(xiàn),但我打算之后再講.

2.get
函數(shù)格式:Model.objects.get(...)
示例:

s1=Stu.objects.get(id=2)     #小華
s2=Stu.objects.get(age=10)   #小明
s3=Stu.objects.get(className=2)        #報(bào)錯(cuò),查到不止一個(gè)數(shù)據(jù)
s4=Stu.objects.get(id=5)        #報(bào)錯(cuò),查不到數(shù)據(jù)

get中使用關(guān)鍵字參數(shù)的傳遞方法(不要問(wèn)我什么是關(guān)鍵字參數(shù)的傳遞方法,有問(wèn)題請(qǐng)自行購(gòu)買并閱讀,《Python語(yǔ)言從入門到精通》)限定條件,如果查不到或查到很多會(huì)報(bào)錯(cuò)哦,建議在里面使用主鍵進(jìn)行查找.返回一個(gè)Model的實(shí)例.

3.filter
函數(shù)格式:Model.objects.filter(...)
參數(shù):同樣適用關(guān)鍵字參數(shù)傳遞方法,可以有多條數(shù)據(jù)滿足條件.如果不填,可以直接返回所有結(jié)果,但沒(méi)有這個(gè)必要,因?yàn)槟憧梢允褂昧硪粋€(gè)all函數(shù)來(lái)實(shí)現(xiàn).
返回值:QuerySet
QuerySet的方法和技巧
首先,你可以使用list將其轉(zhuǎn)換為標(biāo)準(zhǔn)列表,但會(huì)損失一些額外的方法.

stus=list(Stu.objects.filter()) 

因?yàn)楹芏嗖僮鞫际窃谶@種查詢對(duì)象上的,所以介紹一下這個(gè)queryset
你可以使用len獲取長(zhǎng)度length=len(Stu.objects.filter()).
它也是一個(gè)可迭代對(duì)象.
對(duì)象方法則有

stus=Stu.objects.filter(className=2)

stus.first        #第一個(gè)數(shù)據(jù)
stus.last        #最后一個(gè)數(shù)據(jù)
stus.order_by        #按字段排序
stus.exits        #判斷某條數(shù)據(jù)是否存在
stus.values        #獲取查詢到結(jié)果中一列的值

如果你竟然直接進(jìn)行了這類操作

s=stus.first

別怪我沒(méi)在上面寫這是對(duì)象方法.

接下來(lái),讓我們介紹一下裝逼底層的玩法:直接使用裝逼的SQL語(yǔ)句完成所有操作.這種方式不依賴model,但你要引入另一個(gè)模塊

from django.db import connection

然后,進(jìn)行這樣的操作:

connection.cursor().execute(command:str)
#command:SQL命令
#返回值:一個(gè)cursor對(duì)象

其中,cursor有還其他一些常用的函數(shù):
close():關(guān)閉此游標(biāo)對(duì)象
fetchone():得到結(jié)`果集的下一行
fetchmany():得到結(jié)果集的下幾行
參數(shù):不傳等于fetchall,否則傳入要得到的行數(shù).
fetchall():得到結(jié)果集中剩下的所有行

以上是這篇文章的全部,錯(cuò)誤的地方懇請(qǐng)指正.
都看到這了,贊賞一下唄(^ ~ ^ ||).

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容