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的主要内容,如果未能解决你的问题,请参考以下文章

Python程序开发——Python实现可增删改查的员工管理系统

python测试开发django-3.url配置

python测试开发django-3.url配置

测试开发:自学Dubbo+Python经验总结分享

Python Web开发:登录实现及功能测试

python测试开发django-58.MySQL server has gone away错误的解决办法