python测试开发django-170.ORM查询之contains和icontains
Posted 上海-悠悠
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python测试开发django-170.ORM查询之contains和icontains相关的知识,希望对你有一定的参考价值。
前言
平常用ORM大部分使用的是get、filter、exclude这三种能满足基本的需求,有时我们需要满足一些复杂的查询场景,在页面上传不同参数满足查询需求。
ORM 条件查询使用field__
结合 condition 的方式来使用的,比如查询包含指定的字符,可以用contains和icontains。
contains和icontains 区别
比如有下面这张表
MyDjango>python manage.py shell
>>> Product.objects.filter(name__contains='yy')
<QuerySet [<Product: Product object (2)>, <Product: Product object (3)>]>
>>> Product.objects.filter(name__icontains='yy')
<QuerySet [<Product: Product object (2)>, <Product: Product object (3)>, <Product: Product object (4)>]>
>>>
contains表示精确大小写,icontains
中的i
表示忽略大小写
filter(name__contains='yy')
是查询name包含小写的yy的内容filter(name__icontains='yy')
是查询name包含yy的字符,不区分大小写
对应SQL语句
SQL 查询like 后面带上 BINARY 就是精确大小写查询
name__contains='yy'
对应sql语句where name like BINARY '%yy%'
name__icontains='yy'
对应SQL 语句where name like '%yy%'
/* BINARY精确大小写yy */
select * from yoyo_product where name like BINARY '%yy%';
/* 忽略大小写yy */
select * from yoyo_product where name like '%yy%';
以上是关于python测试开发django-170.ORM查询之contains和icontains的主要内容,如果未能解决你的问题,请参考以下文章