在Django的模型中执行原始SQL查询的方法


Posted in Python onJuly 21, 2015

有时候你会发现Django数据库API带给你的也只有这么多,那你可以为你的数据库写一些自定义SQL查询。 你可以通过导入django.db.connection对像来轻松实现,它代表当前数据库连接。 要使用它,需要通过connection.cursor()得到一个游标对像。 然后,使用cursor.execute(sql, [params])来执行SQL语句,使用cursor.fetchone()或者cursor.fetchall()来返回记录集。 例如:

>>> from django.db import connection
>>> cursor = connection.cursor()
>>> cursor.execute("""
...  SELECT DISTINCT first_name
...  FROM people_person
...  WHERE last_name = %s""", ['Lennon'])
>>> row = cursor.fetchone()
>>> print row
['John']

connection和cursor几乎实现了标准Python DB-API,你可以访问` http://www.python.org/peps/pep-0249.html <http://www.python.org/peps/pep-0249.html>`__来获取更多信息。 如果你对Python DB-API不熟悉,请注意在cursor.execute() 的SQL语句中使用`` “%s”`` ,而不要在SQL内直接添加参数。 如果你使用这项技术,数据库基础库将会自动添加引号,同时在必要的情况下转意你的参数。

不要把你的视图代码和django.db.connection语句混杂在一起,把它们放在自定义模型或者自定义manager方法中是个不错的主意。 比如,上面的例子可以被整合成一个自定义manager方法,就像这样:

from django.db import connection, models

class PersonManager(models.Manager):
  def first_names(self, last_name):
    cursor = connection.cursor()
    cursor.execute("""
      SELECT DISTINCT first_name
      FROM people_person
      WHERE last_name = %s""", [last_name])
    return [row[0] for row in cursor.fetchone()]

class Person(models.Model):
  first_name = models.CharField(max_length=50)
  last_name = models.CharField(max_length=50)
  objects = PersonManager()

然后这样使用:

>>> Person.objects.first_names('Lennon')
['John', 'Cynthia']
Python 相关文章推荐
Python采用socket模拟TCP通讯的实现方法
Nov 19 Python
Python赋值语句后逗号的作用分析
Jun 08 Python
Python实现的多叉树寻找最短路径算法示例
Jul 30 Python
Python使用sorted对字典的key或value排序
Nov 15 Python
Python实现带下标索引的遍历操作示例
May 30 Python
matplotlib命令与格式之tick坐标轴日期格式(设置日期主副刻度)
Aug 06 Python
python实现连续变量最优分箱详解--CART算法
Nov 22 Python
Python3与fastdfs分布式文件系统如何实现交互
Jun 23 Python
Python实现弹球小游戏
Aug 01 Python
Python代码注释规范代码实例解析
Aug 14 Python
python搜索算法原理及实例讲解
Nov 18 Python
使用Python画了一棵圣诞树的实例代码
Nov 27 Python
在Django的模型中添加自定义方法的示例
Jul 21 #Python
详解Python的Django框架中Manager方法的使用
Jul 21 #Python
通过数据库对Django进行删除字段和删除模型的操作
Jul 21 #Python
通过数据库向Django模型添加字段的示例
Jul 21 #Python
Django的数据模型访问多对多键值的方法
Jul 21 #Python
举例讲解Django中数据模型访问外键值的方法
Jul 21 #Python
编写自定义的Django模板加载器的简单示例
Jul 21 #Python
You might like
PHP define函数的使用说明
2008/08/27 PHP
用PHP书写安全的脚本代码
2012/02/05 PHP
php生出随机字符串
2017/07/06 PHP
javascript面向对象入门基础详细介绍
2012/09/05 Javascript
Jquery 切换不同图片示例代码
2013/12/05 Javascript
javascript的document.referrer浏览器支持、失效情况总结
2014/07/18 Javascript
jQuery 1.9移除了$.browser可以使用$.support来替代
2014/09/03 Javascript
jQuery插件formValidator自定义函数扩展功能实例详解
2015/11/25 Javascript
XML、HTML、CSS与JS的区别整理
2016/02/18 Javascript
Knockoutjs 学习系列(一)ko初体验
2016/06/07 Javascript
一个仿微博登陆邮箱提示框js开发案例
2016/07/28 Javascript
Web性能优化系列 10个提升JavaScript性能的技巧
2016/09/27 Javascript
JavaScript实现拖拽元素对齐到网格(每次移动固定距离)
2016/11/30 Javascript
JavaScript中的子窗口与父窗口的互相调用问题
2017/02/08 Javascript
基于JS实现移动端左滑删除功能
2017/07/28 Javascript
Element-ui table中过滤条件变更表格内容的方法
2018/03/02 Javascript
async/await让异步操作同步执行的方法详解
2019/11/01 Javascript
JQuery中DOM节点的操作与访问方法实例分析
2019/12/23 jQuery
js代码实现轮播图
2020/05/04 Javascript
Layui弹框中数据表格中可双击选择一条数据的实现
2020/05/06 Javascript
vue element table中自定义一些input的验证操作
2020/07/18 Javascript
[03:46]DAC趣味视频-中文考试.mp4
2017/04/02 DOTA
[48:54]VGJ.T vs infamous Supermajor小组赛D组败者组第一轮 BO3 第二场 6.3
2018/06/04 DOTA
python使用win32com在百度空间插入html元素示例
2014/02/20 Python
解读Django框架中的低层次缓存API
2015/07/24 Python
Python实现删除当前目录下除当前脚本以外的文件和文件夹实例
2015/07/27 Python
Python如何安装第三方模块
2020/05/28 Python
django数据模型中null和blank的区别说明
2020/09/02 Python
Restful_framework视图组件代码实例解析
2020/11/17 Python
深入理解HTML5定时器requestAnimationFrame的使用
2018/12/12 HTML / CSS
“四风”问题的主要表现和危害思想汇报
2014/09/19 职场文书
爱的教育读书笔记
2015/06/26 职场文书
优秀党员先进事迹材料2016
2016/02/29 职场文书
简单了解 MySQL 中相关的锁
2021/05/25 MySQL
Python多个MP4合成视频的实现方法
2021/07/16 Python
解决Python保存文件名太长OSError: [Errno 36] File name too long
2022/05/11 Python