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%'; 
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值