首页 > 数据库技术 > 详细

Django之ORM执行原生sql语句

时间:2019-07-21 20:07:11      阅读:85      评论:0      收藏:0      [点我收藏+]

  django中的ORM提供的操作功能有限,在模型提供的查询API不能满足实际工作需要时,可以在ORM中直接执行原生sql语句。

Django 提供两种方法使用原生SQL进行查询:一种是使用raw()方法,进行原生SQL查询并返回模型实例;另一种是完全避开模型层,直接执行自定义的SQL语句。

 

raw()方法执行原生sql语句:

# raw()方法执行原生sql(调用的类名不区分是谁,只要存在均可执行)

  ret=models.Book.objects.raw(‘select * from app01_book‘)

  # ret=models.Publish.objects.raw(‘select * from app01_book‘)

  for book in ret:

      print(book.book_name)

      # print(book.__dict__)

 

直接执行自定义原生sql语句:

#直接执行自定义原生sql(完全避开模型层,类似pymysql操作)

  from django.db import connection

  cursor=connection.cursor()

  cursor.execute(‘select * from app01_book‘)

  ret=cursor.fetchall()

  print(ret)#((2, ‘小时光‘, Decimal(‘10.00‘), 2), (3, ‘未来可期‘, Decimal(‘33.00‘), 1), (4, ‘打破思维里的墙‘, Decimal(‘11.00‘), 2), (5, ‘时光不散‘, Decimal(‘11.00‘), 3))

 

django中的ORM提供的操作功能有限,在模型提供的查询API不能满足实际工作需要时,可以在ORM中直接执行原生sql语句。

Django 提供两种方法使用原生SQL进行查询:一种是使用raw()方法,进行原生SQL查询并返回模型实例;另一种是完全避开模型层,直接执行自定义的SQL语句。

 

raw()方法执行原生sql语句:

# raw()方法执行原生sql(调用的类名不区分是谁,只要存在均可执行)

  ret=models.Book.objects.raw(‘select * from app01_book‘)

  # ret=models.Publish.objects.raw(‘select * from app01_book‘)

  for book in ret:

      print(book.book_name)

      # print(book.__dict__)

 

直接执行自定义原生sql语句:

#直接执行自定义原生sql(完全避开模型层,类似pymysql操作)

  from django.db import connection

  cursor=connection.cursor()

  cursor.execute(‘select * from app01_book‘)

  ret=cursor.fetchall()

  print(ret)#((2, ‘小时光‘, Decimal(‘10.00‘), 2), (3, ‘未来可期‘, Decimal(‘33.00‘), 1), (4, ‘打破思维里的墙‘, Decimal(‘11.00‘), 2), (5, ‘时光不散‘, Decimal(‘11.00‘), 3))

 

Django之ORM执行原生sql语句

原文:https://www.cnblogs.com/open-yang/p/11222338.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!