如何解析Django中执行原生MySQL语句的具体步骤?

2026-05-05 12:031阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计414个文字,预计阅读时间需要2分钟。

如何解析Django中执行原生MySQL语句的具体步骤?

1. 使用extra方法+解释:结果集修改器,提供额外查询参数的机制+说明:依赖model模型+使用方式:用在where后:Book.objects.filter(publisher_id='1').extra(where=['title=python学01'])+用在select后:

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

如何解析Django中执行原生MySQL语句的具体步骤?

  解释:利用游标执行

  导入: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() 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计414个文字,预计阅读时间需要2分钟。

如何解析Django中执行原生MySQL语句的具体步骤?

1. 使用extra方法+解释:结果集修改器,提供额外查询参数的机制+说明:依赖model模型+使用方式:用在where后:Book.objects.filter(publisher_id='1').extra(where=['title=python学01'])+用在select后:

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

如何解析Django中执行原生MySQL语句的具体步骤?

  解释:利用游标执行

  导入: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() 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。