Django执行源生mysql语句实现过程解析
1.使用extra方法
解释:结果集修改器,一种提供额外查询参数的机制
说明:依赖model模型
使用方式:
用在where后:
Book.objects.filter(publisher_id="1").extra(where=["title='python学习1'"])
用在select后
Book.objects.filter(publisher_id="1").extra(select={"count":"selectcount(*)fromhello_book"})
2.使用raw方法
解释:执行原始sql并返回模型
说明:依赖model多用于查询
使用方式:
book=Book.objects.raw("select*fromhello_book")#返回模型实例 foriteminbook: print(item.title)
3.执行自定义SQL
解释:利用游标执行
导入:fromdjango.dbimportconnection
说明:不依赖model
使用方式:
fromdjango.dbimportconnection
cursor=connection.cursor()
#插入
cursor.execute("insertintohello_author(name)values('xiaol')")
#更新
cursor.execute("updatehello_authorsetname='xiaol'whereid=1")
#删除
cursor.execute("deletefromhello_authorwherename='xiaol'")
#查询
cursor.execute("select*fromhello_author")
#返回一行
raw=cursor.fetchone()
print(raw)
#返回所有
#cursor.fetchall()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。