thinkphp6 自定义的查询构造器类

前景需求:在查询的 时候我们经常会有一些通用的,查询条件,但是又不想每次都填写一遍条件,这个时候就需要重写查询类(Query)

我目前使用的thinkphp版本是6.1

首先自定义CustomQuery类继承于Query

复制代码
<?php

namespace app;
use think\db\BaseQuery;
use think\db\Query;

class CustomQuery extends Query {
    // 本人的需要是,当查询用户表中的数据时,如果条件是email不为null,那么同时email也不能时空字符串
    public function whereNotNull(string $field, string $logic = 'AND'){
        $obj = parent::whereNotNull($field,$logic);
        $table = self::getTable();
        $alias = $this->getOptions('alias');

        $fields = ['email','__TABLE__.email'];
        if ($alias&&isset($alias[$table])&&!empty($alias[$table])){
            $fields[] = $alias[$table].'.email';
        }
        if (in_array($field,$fields)&&$table=='s_user'){
            $obj->where($field,'<>','');
        }
        return $obj;
    }
}

然后修改掉通用的查询类(在配置文件database.php)文件中增加

复制代码
 'query'           => CustomQuery::class,

在此处配置的原因可见下图:

注意:这种方法是替换整个模块或者整个项目中的查询类,目前还未找到某个Model的查询类替换,如有方法,请赐教

相关推荐
wt_cs几秒前
身份证实名认证接口数字时代的信任基石-node.js实名认证集成
开发语言·node.js·php
普兰店拉马努金15 分钟前
【高中数学/古典概率】4红2黑六选二,求取出两次都是红球的概率
java·概率
智商低情商凑15 分钟前
CAS(Compare And Swap)
java·jvm·面试
yangmf204016 分钟前
使用 Logstash 迁移 MongoDB 数据到 Easysearch
java·elasticsearch·搜索引擎
皮实的芒果17 分钟前
前端实时通信方案对比:WebSocket vs SSE vs setInterval 轮询
前端·javascript·性能优化
爱编程的鱼18 分钟前
C# 结构(Struct)
开发语言·人工智能·算法·c#
Tiger_shl19 分钟前
【Python语言基础】24、并发编程
java·数据库·python
FAQEW22 分钟前
Spring boot 中的IOC容器对Bean的管理
java·spring boot·后端·bean·ioc容器
il23 分钟前
Deepdive into Tanstack Query - 2.0 Query Core 概览
前端·javascript
Shawn59025 分钟前
前端时间管理实践:从时间标准化到工程化封装
前端·javascript