开源web框架django知识总结(四)

本文详细介绍了Django ORM的查询操作,包括all()、values()、values_list()、order_by()方法,以及条件查询filter()、exclude()、get()。还涉及到数据的更新、删除操作,并探讨了F对象和Q对象的使用。此外,文章提到了聚合查询和原生SQL操作,展示了如何进行整表聚合和分组聚合,以及如何安全地进行原生数据库操作。
摘要由CSDN通过智能技术生成

开源web框架django知识总结(四)

一、ORM查询操作

查询简介:

数据库的查询需要使用管理器对象进行

通过MyModel.objects管理器方法调用查询方法
在这里插入图片描述
all()方法

用法:MyModel.objects.all() 作用:查询MyModel实体中所有数据,等同于 select * from table 返回值:QuerySet容器对象,内部存放MyModel实例

#在shell中执行
python manage.py shell
>>> from bookstore.models import Book
>>> books = Book.objects.all()
>>> books
<QuerySet [<Book: Book object (1)>, <Book: Book object (2)>, <Book: Book object (3)>, <Book: Book object (4)>, <Book: Book object (5)>]>
>>> for book in books:
...     print("书名",book.title,"出版社",book.pub) # 注意格式tab键
...
书名 Python 出版社 清华大学出版社
书名 Django 出版社 清华大学出版社
书名 Jquery 出版社 机械工业出版社
书名 Linux 出版社 机械工业出版社
书名 HTML5 出版社 清华大学出版社
>>>
	
##################################################	

#可以在模型类中定义“__str__"方法,自定义QuerySet中的输出格式,例如   注意缩进
	def __str__(self):
		return '%s_%s_%s_%s'%(self.title, self.pub, self.price, self.market_price)

在这里插入图片描述
value(‘列1’,‘列2’,…) 方法

​ 用法:MyModel.objects.value(…) 作用:查询部分列的数据并返回。等同于select 列1,列2 from xxx 返回值:QuerySet 返回查询结果容器,容器内存字典,每个字典代表一条数据,格式为:{‘列1’:值1,‘列2’:值2}

>>> from bookstore.models import Book
>>> books = Book.objects.all()
>>> books
<QuerySet [<Book: Python_清华大学出版社_20.00_25.00>, <Book: Django_清华大学出版社_70.00_75.00>, <Book: Jquery_机械工业出版社_90.00_85.00>, <Book: Linux_机械工业出版社_80.00_60.00>, <Book: HTML5_清华大学出版社_90.00_105.00>]>
>>> a2 = Book.objects.values('title','pub')
>>> a2
<QuerySet [{
   'title': 'Python', 'pub': '清华大学出版社'}, {
   'title': 'Django', 'pub': '清华大学出版社'}, {
   'title': 'Jquery', 'pub': '机械工业出版社'}, {
   'title': 'Linux', 'pub': '机械工业出版社'}, {
   'title': 'HTML5', 'pub': '清华大学出版社'}]>
>>> for book in a2:
...      print(book)
...
{
   'title': 'Python', 'pub': '清华大学出版社'}
{
   'title': 'Django', 'pub': '清华大学出版社'}
{
   'title': 'Jquery', 'pub': '机械工业出版社'}
{
   'title': 'Linux', 'pub': '机械工业出版社'}
{
   'title': 'HTML5', 'pub': '清华大学出版社'}

>>> for book in a2:
...     print(book['title'])
...
Python
Django
Jquery
Linux
HTML5
>>>

在这里插入图片描述
value_list(‘列1’,‘列2’,…) 方法

用法:MyModel.objects.value_list(…) 作用:返回元组形式的查询结果。等同于select 列1,列2 from xxx 返回值:QuerySet 容器对象,内部存放”元组“,会将查询出来的数据封装到元组中,再封装到查询集合QuerySet 中

>>> a3 = Book.objects.values_list('title','pub')
>>> a3
<QuerySet [('Python', '清华大学出版社'), ('Django', '清华大学出版社'), ('Jquery', '机械工业出版社'), ('Linux', '机械工业出版社'), ('HTML5', '清华大学出版社')]>
>>> for book in a3:
...     print(book)
...
('Python', '清华大学出版社')
('Django', '清华大学出版社')
('Jquery', '机械工业出版社')
('Linux', '机械工业出版社')
('HTML5', '清华大学出版社')
>>> for book in a3:
...     print(book[0])
...
Python
Django
Jquery
Linux
HTML5


在这里插入图片描述
order_by()方法

​ 用法:MyModel.objects.order_by(’-列’,‘列’) 作用:与all()方法不同,它会用SQL语句的ORDER BY子句对查询结果进行,根据某个字段选择性的进行排序

​ 说明:默认是按照升序排序,降序则需要在”列“前增加,‘-’号,表示

>>> a4 = Book.objects.order_by('-price')
>>> a4
<QuerySet [<Book: Jquery_机械工业出版社_90.00_85.00>, <Book: HTML5_清华大学出版社_90.00_105.00>, <Book: Linux_机械工业出版社_80.00_60.00>, <Book: Django_清华大学出版社_70.00_75.00>, <Book: Python_清华大学出版社_20.00_25
  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

主打Python

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值