Django執(zhí)行源生mysql語句實(shí)現(xiàn)過程解析
1.使用extra方法
解釋:結(jié)果集修改器,一種提供額外查詢參數(shù)的機(jī)制
說明:依賴model模型
使用方式:
用在where后:
Book.objects.filter(publisher_id="1").extra(where=["title='python學(xué)習(xí)1'"])
用在select后
Book.objects.filter(publisher_id="1").extra(select={"count":"select count(*) from hello_book"})
2.使用raw方法
解釋:執(zhí)行原始sql并返回模型
說明:依賴model多用于查詢
使用方式:
book = Book.objects.raw("select * from hello_book") #返回模型實(shí)例 for item in book: print(item.title)
3.執(zhí)行自定義SQL
解釋:利用游標(biāo)執(zhí)行
導(dǎo)入:from django.db import connection
說明:不依賴model
使用方式:
from django.db import connection
cursor = connection.cursor()
# 插入
cursor.execute("insert into hello_author(name) values('xiaol')")
# 更新
cursor.execute("update hello_author set name='xiaol' where id=1")
# 刪除
cursor.execute("delete from hello_author where name='xiaol'")
# 查詢
cursor.execute("select * from hello_author")
# 返回一行
raw = cursor.fetchone()
print(raw)
# 返回所有
# cursor.fetchall()
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
pytest配置項(xiàng)目不同環(huán)境URL的實(shí)現(xiàn)
pytest-base-url是pytest的第三方插件,主要用來幫助我們進(jìn)行切換測試環(huán)境地址,下面就來介紹一下配置不同環(huán)境URL的實(shí)現(xiàn),感興趣的可以了解一下2024-02-02Python利用wxPython實(shí)現(xiàn)ocr識(shí)別圖片漢字程序
在這篇博客中,我們將介紹一個(gè)如何使用wxPython構(gòu)建的簡單OCR識(shí)別圖片漢字應(yīng)用程序,文章的示例代碼講解詳細(xì),感興趣的小伙伴可以學(xué)習(xí)一下2023-08-08Python調(diào)用百度AI實(shí)現(xiàn)圖片上表格識(shí)別功能
這篇文章主要給大家介紹了關(guān)于Python調(diào)用百度AI實(shí)現(xiàn)圖片上表格識(shí)別功能的相關(guān)資料,在Python環(huán)境下,利用百度AI開放平臺(tái)文字識(shí)別技術(shù),對(duì)表格類圖片進(jìn)行識(shí)別,需要的朋友可以參考下2021-09-09CentOS 7下安裝Python3.6 及遇到的問題小結(jié)
這篇文章主要介紹了CentOS 7下安裝Python3.6 及遇到的問題小結(jié),需要的朋友可以參考下2018-11-11