当前位置:首页 > php > 正文内容

thinkphp6 搜索功能实现

zhangsir3年前 (2023-01-09)php347

一,thinkphp6搜索功能实现

1创建模型(例如User模型)

模型类函数的命名规范:searchFieldNameAttr,FieldName根据自己的需要随意命名。例如下面的searchNameAttr。

<?php
namespace app\model;

use think\Model;

class User extends Model 
{
    public function searchNameAttr($query, $value, $data)
    {
            //name字段的模糊查询
        $query->where('name','like', '%' . $value . '%');
    }
    
    public function searchCreateTimeAttr($query, $value, $data)
    {
            //添加时间字段的限制条件
        $query->whereBetweenTime('create_time', $value[0], $value[1]);
    }    
}

2控制器

User::withSearch(['name','create_time'], [ 'name' => 'think',     'create_time' => ['2018-8-1','2018-8-5'],        'status' => 1    ]) ->select();


User::withSearch(['name','create_time'], [
        'name'=>'think',
        'create_time'=>['2018-8-1','2018-8-5'],
        'status'=>1
    ])
->select();

注解:User::withSearch是使用thinkphp6的搜索器触发方法,['name','create_time']是上面User模型类的searchNameAttr和searchCreateTimeAttr函数,['name'=>'think','create_time' =>['2018-8-1','2018-8-5'],status'=>1]是参数。


官方搜索器文档

zhangsir版权a1防采集https://mianka.xyz

扫描二维码推送至手机访问。

版权声明:本文由zhangsir or zhangmaam发布,如需转载请注明出处。

本文链接:https://www.mianka.xyz/post/94.html

标签: phpthinkphp
分享给朋友:

“thinkphp6 搜索功能实现” 的相关文章

php 爬虫函数

 public function request_post($url = '', $param = '')     {   ...

php怎么判断是不是手机号

php怎么判断是不是手机号肯定要用正则表达式解决了。$g = "/^1[34578]\d{9}$/"上面是正则表达式,那怎么用PHP来写呢?$g = "/^1[34578]\d{9}$/" if(preg_match(...

think PHP返回上一页的办法!

think PHP返回上一页的办法!输入如下代码即可返回上一页return redirect($_SERVER["HTTP_REFERER"]);...

thinkphp6 对于大数据的性能优化处理

一,分页功能分页功能建议使用官方提供的paginateX分页查询方法,如下是官方原话:对于大量数据的分页查询,系统提供了一个高性能的paginateX分页查询方法,用法和paginate分页查询存在一定区别。如果你要分页查询的数据量在百万级以上,使用paginateX方法会有明显的提升,尤其是在分页...

PHP命令执行的函数

system();System()函数的主要功能是在系统权限允许的情况是执行系统命令,windows系统和Linux系统都可以执行,Windows系统下可执行可执行文件(.exe、.bat等),也可执行cmd命令,Linux下用途更广,因为Linux系统就是基于命令行的,如基本的ls、cp、rm等s...

用PHP写个递归函数

以下是一个使用 PHP 编写的递归函数示例,该函数将计算给定数字的阶乘:function factorial($n) {     if ($n <= 1) {   &nb...