Django使用原生SQL查询数据库详解

关于使用Django进行原生SQL查询,我们需要先了解一下Django提供给我们的两种方式:

  1. 使用自定义的SQL作为Django查询的一部分,基本与SQLalchemy等ORM框架使用方式相同。此方式执行的是基于Django所定义的模型中的数据查询,且在Django的查询集上已经默认处理了ORM的一些坑点使其可读性更清晰;

  2. 使用Django提供的 django.db.connectionsconnection.cursor() 方法,直接在数据库中执行原生SQL语句,执行的是纯净原生SQL查询,但相较于前面的方式更为麻烦。

接下来,我们以两个示例详细介绍这两种方式的使用方法。

使用自定义SQL查询

这种方式需要借助Django提供的 Model.objects.raw() 方法,并传入自定义SQL语句,因会执行Query拼接操作,所以仅在需要自定义的数据查询时使用。

下面是示例:

from django.db import models

class Person(models.Model):
    first_name = models.CharField(max_length=30)
    last_name = models.CharField(max_length=30)

def get_person():
    return Person.objects.raw('SELECT * FROM myapp_person')

在这里,我们自定义了SQL SELECT * FROM myapp_person 查询Person这个模型中的数据。

直接执行SQL

使用Django提供的 connection.cursor() 搭配 connection.execute() 方法即可执行原生SQL。

from django.db import connection

with connection.cursor() as cursor:
    cursor.execute("SELECT * FROM myapp_person")
    row = cursor.fetchone()

在这里,我们使用 cursor.execute() 方法来执行我们的原生SQL语句,接下来就可以通过获得的 row 来访问数据。

当然,除了 fetchone() 方法还支持其他的方法,如 fetchall()fetchmany() 等,具体使用请查看Django官方文档。

以上就是Django使用原生SQL查询数据库的完整攻略及两个示例说明,希望能帮到你。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django使用原生SQL查询数据库详解 - Python技术站

(0)
上一篇 2023年5月16日
下一篇 2023年5月16日

相关文章

  • PyCharm创建Django项目的简单步骤记录

    下面是详细讲解“PyCharm创建Django项目的简单步骤记录”的完整攻略。 1.环境准备 在开始创建Django项目之前,需要准备好以下环境: Python环境,可以到https://www.python.org/downloads/下载Python的安装包进行安装。 PyCharm IDE,可以到https://www.jetbrains.com/py…

    Django 2023年5月16日
    00
  • django与easyui使用过程中遇到的问题

    最近要使用django前台用easyui,发现当从后台获取数据过程中会出现跨域问题。 多次尝试后发现将ajax的方法设置为GET就没问题了 代码如下: $(‘#syslog_1′).datagrid({ url:’/bookapp/book/test/’, toolbar:’#toolbar’, fitColumns:true, iconCls:’icon-…

    Django 2023年4月13日
    00
  • 在Django中写mqtt脚本并使用

    在Django中写mqtt脚本并使用 表结构如下      新建一个module文件夹用来存放自编脚本 1 # __author: gy-chen 2 # data: 2020/5/23 3 # -*- coding: UTF-8 -*- 4 5 6 # 为了能在外部脚本中调用Django ORM模型,必须配置脚本环境变量,将脚本注册到Django的环境变量…

    Django 2023年4月11日
    00
  • 使用Django2.0打造小程序助手

    打造个人助手 主角: Django2.0 微信小程序(2017年元旦发布) 技术要求: python3开发基础 Django开发基础 HTML+CSS+JS 开发环境: Python开发环境:Python3.5+pycharm 小程序开发环境:微信开发者工具 系统开发环境:Windows(开发)+linux(部署) 依赖环境&工具 Postman(模…

    Django 2023年4月9日
    00
  • django项目实现应用系统的自动更新

    需求:有多个应用系统部署在不同的WINDOWS机器上,应用通过IIS对外发布,并且同一个应用都有在多台机器上面实现负载均衡,每次应用发布更新手工处理不仅效率低,还存在一定的误操作的风险,为提高工作效率,使用DJANGO发布的站点对各个应用实现自动更新 1、应用系统信息的表结构 models.py class systeminfo(models.Model):…

    Django 2023年4月16日
    00
  • Django笔记十六之aggregate聚合操作

    本文首发于微信公众号:Hunter后端原文链接:Django笔记十六之aggregate聚合操作 这一篇笔记介绍一下关于聚合的操作,aggregate。 常用的聚合操作比如有平均数,总数,最大值,最小值等等 用到的 model 如下 class Author(models.Model): name = models.CharField(max_length=…

    2023年4月10日
    00
  • Django models.py应用实现过程详解

    下面就为你详细讲解“Django models.py应用实现过程详解”的完整攻略。 1. 前提知识 在正式开始之前,我们需要先了解一些前提知识: Django框架的基本概念和使用方法 Python的基础语法和面向对象编程思想 数据库的基础知识以及SQL语句的使用 如果你还不熟悉这些知识,请先进行相关学习,否则可能会对本文的理解造成不便。 2. Django的…

    Django 2023年5月16日
    00
  • Django自定义Auth模块方式

    Django默认提供了认证系统Auth模块,认证的时候,会使用auth模块里面给提供的表。认证系统包含: 用户管理 权限 用户组 密码哈希系统 用户登录或内容显示的表单和视图 一个可插拔的后台系统 admin Django默认用户的认证机制依赖Session机制,在项目中将引入JWT认证机制,将用户的身份凭据存放在Token中,然后对接Django的认证系统…

    Django 2023年4月12日
    00
合作推广
合作推广
分享本页
返回顶部