zoukankan      html  css  js  c++  java
  • 12.Django数据库操作(执行原生SQL)

    1.使用extra方法

      解释:结果集修改器,一种提供额外查询参数的机制

      说明:依赖model模型

      用在where后:

        Book.objects.filter(publisher_id="1").extra(where=["title='python学习1'"])    

      用在select后  

        Book.objects.filter(publisher_id="1").extra(select={"count":"select count(*) from hello_book"})

    2.使用raw方法

      解释:执行原始sql并返回模型

      说明:依赖model多用于查询

      用法:

        book = Book.objects.raw("select * from hello_book")
        for item in book:
          print(item.title)

    3.执行自定义SQL

      解释:利用游标执行

      导入:from django.db import connection

      说明:不依赖model

      用法:  

        from django.db import connection

        cursor = connection.cursor()
        #插入
        cursor.execute("insert into hello_author(name) values('xiaol')")
        #更新
        cursor.execute("update hello_author set name='xiaol' where id=1")
        #删除
        cursor.execute("delete from hello_author where name='xiaol'")
        #查询
        cursor.execute("select * from hello_author")
        #返回一行
        raw = cursor.fetchone()
        print(raw)
        # #返回所有
        # cursor.fetchall()

  • 相关阅读:
    Makefile使用函数
    Makefile条件判断
    Makefile使用变量
    Makefile书写命令
    Makefile书写规则
    Makefile总述
    Makefile基础知识
    LEETCODE刷题 替换空格
    LEETCODE刷题 二维数组查找
    【Intellij IDEA 奇淫技巧】自动生成serialVersionUID的设置
  • 原文地址:https://www.cnblogs.com/413xiaol/p/6504856.html
Copyright © 2011-2022 走看看