django执行源生sql

Posted sui776265233

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django执行源生sql相关的知识,希望对你有一定的参考价值。

执行源生sql在python中我们可以借助pymysql模块来进行执行源生sql关于pymysql执行源生sql可以看我的另外一篇博文:pymysql应用

本篇博客只介绍django中执行的源生sql

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()     

 

以上是关于django执行源生sql的主要内容,如果未能解决你的问题,请参考以下文章

js源生惯性滚动与回弹(备用)

PHP源生验证码

TP5.0源生Excel导出

Django REST framework之解析器实例以及源码流程分析

源生Ribbon介绍 --- 客户端负载均衡器 - 01

Part 2:模型与管理后台