Django中如何直接执行SQL语句

 更新时间:2023年08月24日 09:55:34   作者:程序员学编程  
这篇文章主要介绍了Django中如何直接执行SQL语句问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Django直接执行SQL语句

今天在django views.py看到同事写的代码里面有段关于数据库查询的语句。

因为涉及多个表的查询,所以django 的models的查询无法满足需求,所以直接执行了SQL语句。

他是按照下面的方法实现的。

    try:
        connection = MySQLdb.connect(host=SQL_IP,
                                     user=SQL_USER,
                                     passwd=SQL_PASSWD,
                                     db=SQL_DB, charset='utf8')
        cursor = connection.cursor()
        cmd_query = query_data(request)
        data_sort = sort_data(request)
        cmd = "set session group_concat_max_len = 8000;"
        cursor.execute(cmd)
        ......

看到这段代码,感觉应该重复造了轮子,数据库的链接应该交由django这个框架处理的。于是查看了下官方文档。

django.db.connection 就是上面的同事写的那个connection了。

后面的方法同他的一样执行就是了。即执行

connection.cursor()
cursor.execute(sql, [params])
cursor.fetchone() or cursor.fetchall()

下面是一个简单的例子。

from django.db import connection
def my_custom_sql(self):
    with connection.cursor() as cursor:
        cursor.execute("UPDATE bar SET foo = 1 WHERE baz = %s", [self.baz])
        cursor.execute("SELECT foo FROM bar WHERE baz = %s", [self.baz])
        row = cursor.fetchone()
    return row

如果你项目中有多个数据库的话,django.db.connection也能很方便的选取数据库。

django.db.connections 是一个类字典的结构,允许你使用数据库别名获取connection。

from django.db import connections
with connections['my_db_alias'].cursor() as cursor:
    # Your code here...

使用with作为上下文管理器:

with connection.cursor() as c:
    c.execute(...)

和下面这段代码等效

c = connection.cursor()
try:
    c.execute(...)
finally:
    c.close()

注意的问题:

如果你做了更新或者插入操作需要在代码中使用 :transaction.commit_unless_managed() 来提交数据。

或者使用事务装饰器(例如 commit_on_success)来修饰视图和提供事务控制数据提交。

这样就不用在代码中调用transaction.commit_unless_managed()。

但是,如果你不手动提交修改,你需要使用 transaction.set_dirty() 将事务标识为已脏。

使用 Django ORM 对数据库进行修改时,Django 会自动调用 set_dirty() 。

但如果你使用了原始 SQL ,Django 就无法获得你的 SQL 是否修改了数据。

只有手动调用 set_dirty() 才能确保 Django 知晓哪些修改必须被提交。

from django.db.transaction import commit_on_success
@commit_on_success
def my_custom_sql_view(request, value):
    from django.db import connection, transaction
    cursor = connection.cursor()
    # Data modifying operation
    cursor.execute("UPDATE bar SET foo = 1 WHERE baz = %s", [value])
    # Since we modified data, mark the transaction as dirty
    transaction.set_dirty()
    # Data retrieval operation. This doesn't dirty the transaction,
    # so no call to set_dirty() is required.
    cursor.execute("SELECT foo FROM bar WHERE baz = %s", [value])
    row = cursor.fetchone()
    #transaction.commit_unless_managed()
    return render_to_response('template.html', {'row': row})

如果不使用

参考文献:1、https://docs.djangoproject.com/en/2.0/topics/db/sql/

Django底层实现sql语句

在django中我们可以自己手写底层sql语句,那么如何写呢?

#导入原生sql模块
from django.db import connection
# 获取当前用户关注课程列表
def get_myflow(request):
    # 获取用户id
    uid = request.GET.get('id')
    # 建立游标对象
    cursor = connection.cursor()
    # 链表查询
    cursor.execute('select a.username,c.title from user a left join flows b on a.id=b.uid left join course c on b.cid=c.id where a.id = %s'% uid)
    # 获取结果集
    result = dictfetchall(cursor)
    print(result)
    # 返回结果
    return HttpResponse(json.dumps(result),content_type='application/json')

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • python set内置函数的具体使用

    python set内置函数的具体使用

    这篇文章主要介绍了python set内置函数的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • 分析Python字符串拼接+=和join()哪个速度更快

    分析Python字符串拼接+=和join()哪个速度更快

    这篇文章主要分析了Python中字符串拼接+=和join()哪个速度更快,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02
  • Python中常用的统计检验代码分享

    Python中常用的统计检验代码分享

    统计检验是数据分析中的重要工具,用于检验数据集中的差异、关联和分布等统计性质,本文为大家整理了常见的统计检验方法,希望对大家有所帮助
    2024-01-01
  • python 表达式和语句及for、while循环练习实例

    python 表达式和语句及for、while循环练习实例

    下面小编就为大家带来一篇python 表达式和语句及for、while循环练习实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • PyCharm活动模板设置步骤实现

    PyCharm活动模板设置步骤实现

    很多情况,我们在写代码都会存在经常要写一些简单且又重复的代码,Pycharm中的活动模板可以把这些使用频率很高的一些代码打包起来设置一个快捷键,本文就来介绍一下如何实现
    2023-12-12
  • Python写的服务监控程序实例

    Python写的服务监控程序实例

    这篇文章主要介绍了Python写的服务监控程序实例,本文直接给出实现代码,需要的朋友可以参考下
    2015-01-01
  • python实现文件+参数发送request的实例代码

    python实现文件+参数发送request的实例代码

    这篇文章主要介绍了python实现文件+参数发送request的实例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • Python 中如何将十六进制转换为 Base64

    Python 中如何将十六进制转换为 Base64

    本篇文章将介绍在 Python 中将 hex 转换为 base64 的方法,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-06-06
  • PyTorch CNN实战之MNIST手写数字识别示例

    PyTorch CNN实战之MNIST手写数字识别示例

    本篇文章主要介绍了PyTorch CNN实战之MNIST手写数字识别示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • Pandas中批量替换字符的六种方法总结

    Pandas中批量替换字符的六种方法总结

    这篇文章主要为大家介绍了Pandas中实现批量替换字符的六种方法,文中的示例代码讲解详细,对我们学习或工作有一定帮助,需要的可以参考一下
    2022-03-03

最新评论