Django QuerySet 就学那么一点点,一点点就够了

举报
梦想橡皮擦 发表于 2021/05/26 13:33:19 2021/05/26
【摘要】 橡皮擦,一个逗趣的互联网高级网虫。新的系列,让我们一起进入 Django 世界。 已经完成的文章 滚雪球学 Python 第三轮,Python Web 之 Django 的世界小手哆嗦一下,就能用 Python Django 实现一个微型博客系统Django 做个小后台,细节在完善一点点,滚雪球学 Python 第三阶段 滚雪球学 Python 第...

橡皮擦,一个逗趣的互联网高级网虫。新的系列,让我们一起进入 Django 世界。

已经完成的文章

四、Django QuerySet

4.1 Django Shell

为了便于调试 Django 内置的查询,可以在命令行运行下述代码。

python manage.py shell

  
 
  • 1

运行之后进行到 Python 环境,继而可以进行数据的基本查询。

>>> from blog.models import Blog
>>> Blog.objects.all()
<QuerySet [<Blog: 报告总监,他...在代码里面 “下毒” 了>, <Blog: 去年我年薪 30W,今年我一天做 3 顿饭>, <Blog: 2021年,我已经说服 27 个人不上培训机构了>]>
>>>

  
 
  • 1
  • 2
  • 3
  • 4

导入 Blog 模块之后,使用 Blog.objects.all() 获取全部数据,数据类型为 Django QuerySet。也可以将数据进行循环输出。

blogs = Blog.objects.all()
for blog in blogs:
	print(blog)

  
 
  • 1
  • 2
  • 3

注意在 Shell 中的代码格式问题。

Django QuerySet 就学那么一点点,一点点
还可以查看 Blog.objects.all() 具体的查询语句

>>> Blog.objects.all().query
<django.db.models.sql.query.Query object at 0x0000000004186358>
>>> str(Blog.objects.all().query)
'SELECT "blog_blog"."id", "blog_blog"."title", "blog_blog"."content", "blog_blog"."creatr_time" FROM "blog_blog"'
>>>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

对于 Django 来说,还是 ORM 框架,底层也是 SQL 语句。

4.2 其他查询方法

除了 Blog.objects.all() 以外,在 Django 中还有其它查询方法,例如 Blog.objects.get()

>>> Blog.objects.get(id=1)
<Blog: 报告总监,他...在代码里面 “下毒” 了>

  
 
  • 1
  • 2

该方法当查询不到数据时,会出现如下错误:

blog.models.Blog.DoesNotExist: Blog matching query does not exist.

  
 
  • 1

如果不希望查询不到程序报错,修改代码为下述格式即可。

>>> Blog.objects.filter(id=5)
<QuerySet []>

  
 
  • 1
  • 2

4.3 增加数据、修改数据、删除数据

新增数据
在数据库中新增一条数据,在 Django 中是使用 Blog.objects.create(title="nnnn",content="大好人",creatr_time="2020-10-10") 实现的,注意参数名字与 Blog 类中的名字进行匹配。

>>> Blog.objects.create(title="nnnn",content="大好人",creatr_time="2020-10-10")
<Blog: nnnn>
>>> Blog.objects.all()
<QuerySet [<Blog: 报告总监,他...在代码里面 “下毒” 了>, <Blog: 去年我年薪 30W,今年我一天做 3 顿饭>, <Blog: 2021年,我已经说服 27 个人不上培训机构了>, <Blog: nnnn>]>
>>>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

修改数据
修改记录就是先查后改。

>>> item = Blog.objects.get(id=3)
>>> item
<Blog: 2021年,我已经说服 27 个人不上培训机构了>
>>> item.title = "2020年,我已经说服20个人不上培训机构了"
>>> item
<Blog: 2020年,我已经说服20个人不上培训机构了>
>>> item.save()
>>> item = Blog.objects.get(id=3)
>>> item
<Blog: 2020年,我已经说服20个人不上培训机构了>
>>>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

修改完需要调用 save() 函数,数据才会保存到数据库中,否则会出现下述情形。

>>> item.title= "橡皮擦测试"
>>> item
<Blog: 橡皮擦测试>
>>> item = Blog.objects.get(id=3)
>>> item
<Blog: 2020年,我已经说服20个人不上培训机构了>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

删除数据
查询数据,然后在删除数据。

>>> item = Blog.objects.get(id=4)
>>> item
<Blog: nnnn>
>>> item.delete()
(1, {'blog.Blog': 1})
>>>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

4.4 这篇博客的总结

本篇博客初步了解了 Django QuerySet 的基本使用,核心做的操作是一种 ORM (对象关系映射)操作,后面的博客中还会有所涉及,先掌握基本的使用方式即可。

相关阅读

  1. Python 爬虫 100 例教程,超棒的爬虫教程,立即订阅吧
  2. Python 游戏世界(更新中,目标文章数 50+,现在订阅,都是老粉)
  3. Python 爬虫小课,精彩 9 讲

今天是持续写作的第 120 / 200 天。
如果你想跟博主建立亲密关系,可以关注同名公众号 梦想橡皮擦,近距离接触一个逗趣的互联网高级网虫。
博主 ID:梦想橡皮擦,希望大家点赞评论收藏

文章来源: dream.blog.csdn.net,作者:梦想橡皮擦,版权归原作者所有,如需转载,请联系作者。

原文链接:dream.blog.csdn.net/article/details/115249909

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。