在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中使用sys模板和logging模块获取行号和函数名的方法
Apr 15 Python
python从入门到精通(DAY 3)
Dec 20 Python
python爬虫入门教程--优雅的HTTP库requests(二)
May 25 Python
对python 合并 累加两个dict的实例详解
Jan 21 Python
python-itchat 统计微信群、好友数量,及原始消息数据的实例
Feb 21 Python
VSCode Python开发环境配置的详细步骤
Feb 22 Python
python多线程+代理池爬取天天基金网、股票数据过程解析
Aug 13 Python
Python通过VGG16模型实现图像风格转换操作详解
Jan 16 Python
关于python 跨域处理方式详解
Mar 28 Python
Python如何输出警告信息
Jul 30 Python
GitHub上值得推荐的8个python 项目
Oct 30 Python
Python编写nmap扫描工具
Jul 21 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
Dedecms V3.1 生成HTML速度的优化办法
2007/03/18 PHP
PHP 输出简单动态WAP页面
2009/06/09 PHP
php URL跳转代码 减少外链
2011/06/25 PHP
PHP中round()函数对浮点数进行四舍五入的方法
2014/11/19 PHP
为PHP5.4开启Zend OPCode缓存
2014/12/26 PHP
浅谈php命令行用法
2015/02/04 PHP
PHP实现的简单异常处理类示例
2017/05/04 PHP
PHP JWT初识及其简单示例
2018/10/10 PHP
laravel 关联关系遍历数组的例子
2019/10/10 PHP
PHP中通过getopt解析GNU C风格命令行选项
2019/11/18 PHP
utf-8编码引起js输出中文乱码的解决办法
2010/06/23 Javascript
JS如何将UTC格式时间转本地格式
2013/09/04 Javascript
jquery获取复选框被选中的值
2014/04/10 Javascript
MVVM模式中ViewModel和View、Model有什么区别?
2015/06/19 Javascript
jQuery 全选 全部选 反选 实现代码
2016/08/17 Javascript
BootStrap实现邮件列表的分页和模态框添加邮件的功能
2016/10/13 Javascript
Json按某个键的值进行排序
2016/12/22 Javascript
react-router实现按需加载
2017/05/09 Javascript
微信小程序云开发如何使用npm安装依赖
2019/05/18 Javascript
layui弹出框Tab选项卡的示例代码
2019/09/04 Javascript
解决LayUI加上form.render()下拉框和单选以及复选框不出来的问题
2019/09/27 Javascript
vue2.x 对象劫持的原理实现
2020/04/19 Javascript
JS+CSS实现炫酷光感效果
2020/09/05 Javascript
Python实现在matplotlib中两个坐标轴之间画一条直线光标的方法
2015/05/20 Python
Python利用IPython提高开发效率
2016/08/10 Python
python使用logging模块发送邮件代码示例
2018/01/18 Python
利用Python绘制有趣的万圣节南瓜怪效果
2019/10/31 Python
nginx+uwsgi+django环境搭建的方法步骤
2019/11/25 Python
Python3.7将普通图片(png)转换为SVG图片格式(网站logo图标)动起来
2020/04/21 Python
python中如何打包用户自定义模块
2020/09/23 Python
光声世纪笔试题目
2012/08/25 面试题
六五普法宣传标语
2014/10/06 职场文书
大学生求职意向书
2015/05/11 职场文书
2016年最美孝心少年事迹材料
2016/02/26 职场文书
Nginx优化服务之网页压缩的实现方法
2021/03/31 Servers
Python的三个重要函数详解
2022/01/18 Python