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

thinkphp6 搜索功能实现

zhangsir3年前 (2023-01-09)php346

一,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 搜索功能实现” 的相关文章

composer提示内存不足的解决方法

1.找到php.ini2.打开php.ini3.搜索memory_limit4.把memory_limit=值改大就好了...

php怎么判断是不是手机号

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

Thinkphp6 把用Db类的条件查询转成原生的sql语句

Thinkphp6经常需要查看 SQL 原生语句,这里有两种方式获取:1、getLastSql(), 获取方法前最后一条 SQL 原生语句$a1 = Movies::where('state',1)->limit(10)->select(); $a2...

think PHP返回上一页的办法!

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

thinkphp 使用Filesystem类提示未找到Filesystem类

这是因为thinkphp官方升级了thinkphp版本的原因,只需要更新Filesystem类就行了更新命令行如下:composer require topthink/think-filesystem 1.0.1...

PHP获取当前请求的所有请求头信息

apache_request_headers()函数里面保函了所有的请求头信息//获取请求头 $headers = apache_request_headers(); var_dump($header)这样就打印出所有的请求头信息了。...