时间:2021-07-01 10:21:17 帮助过:3人阅读
本篇博客只介绍django中执行的源生sql
解释:结果集修改器,一种提供额外查询参数的机制
说明:依赖model模型
使用方式:
用在where后: Book.objects.filter(publisher_id="1").extra(where=["title=‘python学习1‘"]) 用在select后 Book.objects.filter(publisher_id="1").extra(select={"count":"select count(*) from hello_book"})
解释:执行原始sql并返回模型
说明:依赖model多用于查询
使用方式:
book = Book.objects.raw("select * from hello_book") #返回模型实例 for item in book: print(item.title)
解释:利用游标执行
导入: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()
django执行源生sql
标签:import upd 额外 class value val mysql 依赖 fetch