【Django】自定义查询器

背景

之前我遇到一个需求,需要根据用户输入的条件去查询比如用户输入name: s*,就查询name以s开头的对象,当然我们可以用django中自带的一些查询操作去实现,比如contains、startswith等等,也可以用把*转成%,然后利用raw方法带入原生sql查询,但是感觉都比较繁琐,下面我们自定义一个查询器去实现它。


本实例使用Django3.2.8

自定义查询器

mysql中模糊查询是用like去判断%标识查询的,我们就自定义一个like,代码很简单

代码如下:

from django.db.models import Lookup
class LikeSearch(Lookup):
    lookup_name = 'like'

    def as_sql(self, compiler, connection):
        lhs, lhs_params = self.process_lhs(compiler, connection)
        rhs, rhs_params = self.process_rhs(compiler, connection)
        params = lhs_params + rhs_params
        return '%s like %s' % (lhs, rhs), params

这样就实现了一个查询器,当然还没完,还需要注册它才能使用

from django.db.models.fields import Field
Field.register_lookup(LikeSearch)

或者使用装饰器注册

@Field.register_lookup
class LikeSearch(Lookup):
	pass

这样就可以使用它了

Model.objects.filter(name__like='%s%')

其他

该文 如有缺陷及不足的地方,欢迎大家提出并纠正
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值