温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Django中如何使用原生sql语句

发布时间:2020-11-06 09:17:28 来源:亿速云 阅读:180 作者:小新 栏目:编程语言

小编给大家分享一下Django中如何使用原生sql语句,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

1.使用extra方法

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

说明:依赖model模型

用法:

1)用在where后:

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

2)用在select后  

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

2.使用raw方法

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

说明:依赖model多用于查询

用法:

1)book = Book.objects.raw("select * from hello_book")    

2)for item in book:      

3)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()

看完了这篇文章,相信你对Django中如何使用原生sql语句有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI