Django的日常使用中,我们会用到Model中的get和filter方法,今天说说两者的区别。...二、再说说Django的filter用法: 如果我们想要获取到一个name是zhangsan的User: user = User.objects.filter(name="zhangsan") 此时会获取到一个...Queryset对象,第一个对象是zhangsan的User对象,此对象跟get获取到的zhangsan是一样的 如果我们要获取到一个age是17的User: user = User.objects.filter...list,不能以list的操作方法进行 三、总结 两者的使用和区别,基本都讲清楚了,我最后想说一下我的想法: 如果有时我们不能确定数据库里是否有你要查询的数据时,我更多的建议大家使用filter方法,而不是用...因为get可能会在查询不到数据时,代码就会报错,导致程序停止运行。 如果数据是确定存在的,通过get能够更准确的获取到你要的数据对象。
就是 Django 中的 QuerySet 的 filter(), exclude() 和 get() 方法中的关键字参数。 筛选条件的形式是 field__lookuptype=value 。...针对这两种情况,Django 用一种很方便的方式来使用 filter() 和 exclude()。对于包含在同一个 filter() 中的筛选条件,查询集要同时满足所有筛选条件。...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...) 但是,与 F() 对象在查询时所不同的是,在filter 和 exclude子句中,你不能在 F() 对象中引入关联关系(NO-Join),你只能引用当前 model 中要更新的字段。...id directly 直接使用SQL 如果你发现某个 SQL 查询用 Django 的数据库映射来处理会非常复杂的话,你可以使用直接写 SQL 来完成。
distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...filter() 等方法中的关键字参数查询都是一起进行“AND” 的。 ...如果你需要执行更复杂的查询(例如OR语句),你可以使用Q对象。...同时,Q 对象可以使用~ 操作符取反,这允许组合正常的查询和取反(NOT) 查询。 示例:查询作者名字是小仙女并且不是2018年出版的书的书名。
你可以通过重写 Manager.get_queryset() 的方法来覆盖 管理器自带的 查询集。get_queryset() 会根据你所需要的属性返回 查询集。...由于 get_queryset() 返回的是一个 查询集 对象,所以你仍可以对它使用 filter(), exclude()和其他 查询集的方法。...() 这个例子还展示了另外一个很有意思的技巧:在同一个模型中使用多个管理器。...创建管理器 * django 1.7 中新增 * 对于上面的例子,同一个方法需要在查询集 和 管理器上创建两份副本,作为替代,QuerySet.as_manager()可以创建一个管理器的实例,它拥有自定义查询集的方法...,你可能想创建一个自定义管理器和一个自定义查询集。
distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...filter() 等方法中的关键字参数查询都是一起进行“AND” 的。...如果你需要执行更复杂的查询(例如OR语句),你可以使用Q对象。...同时,Q 对象可以使用~ 操作符取反,这允许组合正常的查询和取反(NOT) 查询。 示例:查询作者名字是小仙女并且不是2018年出版的书的书名。
作为铁杆Django用户,发现昨天Django进行了更新,且修复了一个SQL注入漏洞。在我印象里这应该是Django第一个SQL注入漏洞,且的确是可能在业务里出现的漏洞,于是进行了分析。..."], "content": "..." } 我要查询作者是phit0n的所有文章,就可以使用Django的queryset: Collection.objects.filter(detail__author...但是熟悉Django的同学也应该知道,Django的queryset使用方法是编写如下查询语句: .filter(detail__author='phith0n') 这个detail__author用户是无法控制的...就是如果你能控制filter方法的参数名,就能通过外键的方式来获取其他表的一些敏感信息。...总的来说,如果你的应用使用了JSONField,且用户可以进入应用的Django-Admin后台,就可以进行SQL注入。
过滤器聚合(Aggregation with Filter) 在 Django 2.0 之前,如果我们想要得到诸如用户总数和活跃用户总数之类的东西,我们不得不求助于条件表达式: from django.contrib.auth.models...如果你正在使用 PostgreSQL,这两个查询将如下所示: SELECT COUNT(id) AS total_users, SUM(CASE WHEN is_active THEN...在大多数 Django 应用程序中,大部分时间都花在等待数据库查询上了。所以,在 SQL 查询上设置超时是一个很好的开始。...事务操作通常会涉及用户和产品的一些属性,所以我们经常使用 select_related 来强制 join 并保存一些查询。 更新交易还会涉及获得一个锁来确保它不被别人获得。 现在,你看到问题了吗?...再举一个例子,这次列中的值不会被很好地排序: [2–9], [1–7], [3–8] 再试着查找 5: [2–9] — 可能在这里 [1–7] — 可能在这里 [3–8] — 可能在这里 索引是无用的
>>> news.channel # 这时的channel是缓存的版本,不会造成数据库访问 方法的调用每次都会触发数据库查询 >>> news = News.objects.get(id=1) >...在同一模型中使用不同字段进行对比过滤 # 查询所有title和sub_title相同的数据 queryset = News.objects.filter(title=F('sub_title')) 使用...')) print cl[0].news_count 如果这些还不足以生成你需要的SQL的话,继续往下看: 使用 QuerySet.extra() 显式的执行SQL语句 cl = Channel.objects.filter...不要获取你不需要的数据 使用 QuerySet.values() 和 values_list() 当只需要一个字段的值,返回list或者dict时,使用 values news_list = News.objects.values...with的使用是关键 每次的QuerySet.count()调用都会产生查询 使用 QuerySet.update() 和 delete() 批量更新使用 QuerySet.update() 批量删除使用
:可以写多个查询条件,默认是且的关系 对应get,filter,exclude参数中可以写查询条件 格式:属性名__条件名=值 1.3F对象 用于查询时字段之间的比较 from django.db.models...order_by 1.7关联查询 1、查询和指定对象关联的数据(重点掌握) 由一查多:一对象.多类名小写__set.all() 由多查一:多对象.外键属性 2、通过模型类进行关联查询 查图书:一类.objects.get...两大特性: 1、惰性查询:只有在使用查询集中的数据时才会进行数据库真正查询操作 2、查询结果的缓存:如果使用同一个查询集时,只有在第一次使用查询集时会进行数据库的查询操作,然后Django框架就会把查询的结果存起来...,下一次再使用这个查询集的时候,使用的是Django之前存储的结果。...优质文章推荐: 公众号使用指南 redis操作命令总结 前端中那些让你头疼的英文单词 Flask框架重点知识总结回顾 项目重点知识点详解 难点理解&面试题问答 flask框架中的一些常见问题
4、这个例子中的CREATE TABLE SQL 语句使用PostgreSQL 语法格式,要注意的是Django 会根据settings 中指定的数据库类型来使用相应的SQL 语句。...5、定义好模型之后,你需要告诉Django _使用_这些模型。你要做的就是修改配置文件中的INSTALL_APPSZ中设置,在其中添加models.py所在应用的名称。...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。...如果你需要执行更复杂的查询(例如OR 语句),你可以使用Q 对象。...=200))) 注意: 查询函数可以混合使用Q 对象和关键字参数。
从失败中获得成功。 沮丧和失败是成功的两个最可靠的垫脚石。 小闫语录: 有些人因为失败而一蹶不振,有些人却凭借失败积累的经验在后期获得成功。失败并不可怕,如果你连面对的勇气都没有,那么你真的不配成功。...2.2数据库ORM支持(对应Flask中的FlaskSQLAlchemy) ORM是对象关系映射,就是将数据库的操作都转化成对类,属性和方法的操作,不用写sql语句了,不用关注你使用的是mysql还是Oracle...all 无 查询模型类对应表格中的所有数据 QuerySet(查询集) get 查询条件 查询满足条件一条且只能有一条数据 模型类对象,查不到会报错DoesNotExist filter 查询条件 返回满足条件的所有数据...聚合 查询时进行聚合操作 字典:{'属性名_聚合类小写':值} count 无 返回查询结果的数目 数字 条件查询: 对应get,filter,exclude参数中可以写查询条件 格式:属性名__条件名...查询结果的缓存 使用同一个查询集时,只有在第一次使用查询集时会进行数据库的查询操作,然后Django框架就会把查询的结果存起来,下一次再使用这个查询集时,使用的Django之前存储的结果。
5、定义好模型之后,你需要告诉Django _使用_这些模型。你要做的就是修改配置文件中的INSTALL_APPSZ中设置,在其中添加models.py所在应用的名称。...所以,如果你也想知道所有图书价格的最大值和最小值,可以这样查询: ?...如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。 ?...如果你需要执行更复杂的查询(例如OR 语句),你可以使用Q 对象。 ?...同时,Q 对象可以使用~ 操作符取反,这允许组合正常的查询和取反(NOT) 查询: ?
配置使用mysql数据库 之前我们使用的是Django中自带的数据库sqlite数据库。 这篇文章让我们切换成mysql,不会MySQL基础的可以去查询数据库篇的文章。...查询函数 我们在Django中通过:模型类.objects属性调用以下函数来进行查询 get: 返回表中满足条件的一条数据,有且只能有一条,查询出多条会报异常。 查询不到数据也会报异常。...all: 返回全部数据,返回的类型是QuerySet。 filter: 返回符合条件的,和get不同,这个可以返回多条数据。返回的类型是QuerySet。...2、缓存 当我们使用同一个查询集的时候,只有第一次是执行到数据库,然后把结果储存起来,当我们再次使用这个查询集的时候,就会调用我们缓存中的数据。...2、多对多 一个老师对应多个学生,一个学生对应多个老师 那么老师表和学生表就是多对多的关系。 我们需要使用ManyToManyField(),那么你会说我定义在那个表里了?定义那个表都行。
users=LjyUser.objects.filter(truename__contains=mykey) #这里使用filter函数从数据库中过滤输入的关键词,truename__contains...主要在这个查询中,我们使用到了filter函数的功能,用来过滤指定字段的数据,结果返回一个列表。如果查询不到,结果就返回一个长度为0的空列表。...在filter方法内,我们使用了真实姓名truename这个字段去进行查询,传入的mykey就是输入的姓名的关键词。...至此,我们查询页面开发完成。 相关文章: python中函数的可变参数 C语言和C#语言有什么区别吗?...【C#编程1000问】 Django框架开发001期 Python+Django开发教程,开启你的第一个django网站应用 Django框架开发002期 Python编程利用PyCharm专业版和社区版开发网站
在前面教程中小编我已经介绍了Django的Queryset特性及高级使用技巧以及Queryset的aggregate和annotate方法。...专业和业余之前的区别就在细节的处理上。为了让大家更直观地看到这两个方法的作用,我们将安装使用django-debug-toolbar这个流行的Django第三方包。...INTERNAL_IPS = [ # … ‘127.0.0.1’, # … ] 当你安装好debug_toolbar后,启动django服务器,打开任何一个页面你都可以看到查询数据库所花时间以及是否有相似及重复的查询...使用debug_toolbar可以让我们更深入地看问题。它提示我们查询了10次数据库,包括3次重复查询,一共耗时8.93ms。 什么?显示一个页面竟用了10次查询?是的,你没看错。...当我们在模板中调用{{ article.category.name }} 和 {{ tag.name }}显示category和tags的名字时,Django还需要重新查询blog_category和blog_tag
实现SQL中的where功能,包括 filter 过滤出多个结果 exclude 排除掉符合条件剩下的结果 get 过滤单一结果 对于过滤条件的使用,上述三个方法相同,故仅以filter进行讲解。...答:使用F对象,被定义在django.db.models中。 语法如下: F(属性名) 例:查询阅读量大于等于评论量的图书。...3) 如果需要实现逻辑或or的查询,需要使用Q()对象结合|运算符,Q对象被义在django.db.models中。...等同于sql中的limit和offset子句。...优质文章推荐: 公众号使用指南 redis操作命令总结 前端中那些让你头疼的英文单词 Flask框架重点知识总结回顾 项目重点知识点详解 难点理解&面试题问答 flask框架中的一些常见问题 团队开发注意事项
Q查询和F查询 Q查询 在filter() 等方法中,查询使用的关键字参数是通过 “SQL AND” 连接起来的。...如果你要执行更复杂的查询(例如,由 SQL OR 语句连接的查询),可以使用 Q 对象。 一个 Q 对象 (django.db.models.Q) 用于压缩关键字参数集合。...=3 F查询 Django 使用 F() 对象来生成一个 SQL 表达式,直接在数据库层面进行操作。...这就把我们上面使用的两个查询——get() 和 save() 减少到只有一个: reporter = Reporters.objects.filter(name='Tintin') reporter.update...根据字段的值来进行查询 F() 在 QuerySet 过滤器中也非常有用,它们可以根据对象的字段值而不是 Python 值的标准来过滤一组对象。F()能将模型字段值与同一模型中的另一字段做比较。
领取专属 10元无门槛券
手把手带您无忧上云