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":"select count(*) from hello_book"}) 2.使用raw方法 解释:执行原始sql并返回模型 说明:依赖model多用于查询 用法: book = Book.objects.raw("select * from hello_book") for item in book: print(item.title) 3.执行自定义SQL 解释:利用游标执行 导入: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()