只需一招,分清QuerySet对象和用户字典对象

2024-03-05 03:32

本文主要是介绍只需一招,分清QuerySet对象和用户字典对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

django查询中模糊的知识点:

filter(blog=blog),
filter(username=username).first()# 上面的两个查询不太懂
# article_list是可迭代的QuerySet对象,支持for循环
# user_obj这个是用户字典对象,不支持for循环

所有支持for循环的数据类型必须是可迭代数据类型!!!

查询当前用户站点下的所有文章

    article_list = models.Article.objects.filter(blog=blog).first()所有支持for循环的数据类型必须是可迭代数据类型,字典不可迭代,所以for循环取值会报错:TypeError: 'Article' object is not iterable,所以article_list必须是可以迭代的对象,QuerySet对象可以迭代,是可迭代对象,那么就要把.first()给去掉

filter() 得到可迭代的QuerySet对象,支持for循环取容器内的元素,在django中推荐使用

    #filter其实就是 筛选功能,相当于你原生sql语句里面的where关键字,返回的结果queryset对象res=models.Books.objects.filter(pk=1,title='张三丰') #支持多个参数,and关系print(res)      #<QuerySet [<Books: 张三丰>]>print('************************')
# 3.get()    在django中不推荐使用# 筛选,获取的是数据对象本身,条件不存在的数据直接报错,并且查询条件必须是唯一的res=models.Books.objects.get(title='西游记')print(type(res))      #如果是数据库中不存在的数据进行查询的话,会报错,因为数据库中没有该数据print('//')
-----------------------------------------------------------------------------------------------------------------------------------
打印结果如下:<QuerySet [<Books: 张三丰>]>************************<class 'app01.models.Books'>//(0.001) SELECT `app01_books`.`id`, `app01_books`.`title`, `app01_books`.`price`, `app01_books`.`kucun`, `app01_books`.`maichu` FROM `app01_books` WHERE `app01_books`.`price` = 766 LIMIT 21; args=(Decimal('766'),)<QuerySet [<Books: 西游记>, <Books: 西游记2>]><class 'django.db.models.query.QuerySet'>************************西游记1000<class 'app01.models.Books'>(0.001) SELECT `app01_books`.`id`, `app01_books`.`title`, `app01_books`.`price`, `app01_books`.`kucun`, `app01_books`.`maichu` FROM `app01_books` WHERE `app01_books`.`price` = 766 ORDER BY `app01_books`.`id` ASC LIMIT 1; args=(Decimal('766'),)

first()

    #功能一, 取queryset 相同数据中的第一个数据对象,# id=3,title='西游记'  id=5,title='西游记2',加上.first()会优先取id=3的数据res = models.Books.objects.filter(price='766')print(res)print(type(res))打印结果如下:<QuerySet [<Books: 西游记>, <Books: 西游记2>]>        如果上面加上.first()就会只取到第一个值 <QuerySet [<Books: 西游记>]><class 'django.db.models.query.QuerySet'>特殊功能如下:
# .first()特殊的功能可以把QuerySet对象转换为字典对象,方便字典对象点属性取值------------88颗星的重点res = models.Books.objects.filter(price='766').first()print(res)print(res.kucun)    通过字典对象,拿到该书的库存print(type(res))
打印结果如下:西游记1000<class 'app01.models.Books'>  

这篇关于只需一招,分清QuerySet对象和用户字典对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/775197

相关文章

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

POJ2001字典树

给出n个单词,求出每个单词的非公共前缀,如果没有,则输出自己。 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.io.UnsupportedEncodingException;

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

Java第二阶段---09类和对象---第三节 构造方法

第三节 构造方法 1.概念 构造方法是一种特殊的方法,主要用于创建对象以及完成对象的属性初始化操作。构造方法不能被对象调用。 2.语法 //[]中内容可有可无 访问修饰符 类名([参数列表]){ } 3.示例 public class Car {     //车特征(属性)     public String name;//车名   可以直接拿来用 说明它有初始值     pu

HTML5自定义属性对象Dataset

原文转自HTML5自定义属性对象Dataset简介 一、html5 自定义属性介绍 之前翻译的“你必须知道的28个HTML5特征、窍门和技术”一文中对于HTML5中自定义合法属性data-已经做过些介绍,就是在HTML5中我们可以使用data-前缀设置我们需要的自定义属性,来进行一些数据的存放,例如我们要在一个文字按钮上存放相对应的id: <a href="javascript:" d

PHP7扩展开发之对象方式使用lib库

前言 上一篇文章,我们使用的是函数方式调用lib库。这篇文章我们将使用对象的方式调用lib库。调用代码如下: <?php $hello = new hello(); $result = $hello->get(); var_dump($result); ?> 我们将在扩展中实现hello类。hello类中将依赖lib库。 代码 基础代码 这个扩展,我们将在say扩展上增加相关代码。sa

vue2实践:el-table实现由用户自己控制行数的动态表格

需求 项目中需要提供一个动态表单,如图: 当我点击添加时,便添加一行;点击右边的删除时,便删除这一行。 至少要有一行数据,但是没有上限。 思路 这种每一行的数据固定,但是不定行数的,很容易想到使用el-table来实现,它可以循环读取:data所绑定的数组,来生成行数据,不同的是: 1、table里面的每一个cell,需要放置一个input来支持用户编辑。 2、最后一列放置两个b

hibernate修改数据库已有的对象【简化操作】

陈科肇 直接上代码: /*** 更新新的数据并并未修改旧的数据* @param oldEntity 数据库存在的实体* @param newEntity 更改后的实体* @throws IllegalAccessException * @throws IllegalArgumentException */public void updateNew(T oldEntity,T newEntity

类和对象的定义和调用演示(C++)

我习惯把类的定义放在头文件中 Student.h #define _CRT_SECURE_NO_WARNINGS#include <string>using namespace std;class student{public:char m_name[25];int m_age;int m_score;char* get_name(){return m_name;}int set_name

react笔记 8-19 事件对象、获取dom元素、双向绑定

1、事件对象event 通过事件的event对象获取它的dom元素 run=(event)=>{event.target.style="background:yellowgreen" //event的父级为他本身event.target.getAttribute("aid") //这样便获取到了它的自定义属性aid}render() {return (<div><h2>{