Django執(zhí)行源生mysql語句實現(xiàn)過程解析
1.使用extra方法
解釋:結(jié)果集修改器,一種提供額外查詢參數(shù)的機制
說明:依賴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") #返回模型實例
for item in book:
print(item.title)
3.執(zhí)行自定義SQL
解釋:利用游標執(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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
以文檔處理為例講解豆包API調(diào)用教程(Python)
這篇文章主要介紹了如何在Linux服務(wù)器上配置和使用豆包大模型的API,通過API處理200萬字的文檔,展現(xiàn)了技術(shù)的發(fā)展和應(yīng)用,需要的朋友可以參考下2025-01-01
python判斷設(shè)備是否聯(lián)網(wǎng)的方法
這篇文章主要為大家詳細介紹了python判斷設(shè)備是否聯(lián)網(wǎng)的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06

