zoukankan      html  css  js  c++  java
  • 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()
  • 相关阅读:
    appium 学习教程
    初识Airtest
    C语言的数据类型
    C#黑白棋制作~
    C#黑白棋制作
    C#编写自动关机程序复习的知识
    C语言的预处理命令
    构建智能DNS域名解析服务器
    NFS共享服务
    安装ftp 并在ftp上构建yum仓库 (内网构建,比如主机上不了网)
  • 原文地址:https://www.cnblogs.com/xiaowangba9494/p/14550293.html
Copyright © 2011-2022 走看看