ThinkPHP6.0 模型搜索器的使用
搜索器用于封装查询条件表达式,必须在模型中定义,只有使用模型操作数据时才能用搜索器。调用搜索器时使用的是数据表字段,可以不用定义搜索器方法,默认是 = 条件;如果不是数据表字段,必须定义对应的搜索器方法。
1. 调用搜索器
直接调用,默认查询条件是 =
UserModel::withSearch(['name'], ['name' => '张三'])
->fetchSql(true)
->select();
SELECT * FROM `user` WHERE `name` = '张三'
在模型中自定义搜索器方法,改变默认的 =
<?php
namespace app\index\model;
class User extends \think\Model
{
public function searchNameAttr($query, $value, $data)
{
$query->where('name','like', $value . '%');
}
}
UserModel::withSearch(['name'], ['name' => '张三'])
->fetchSql(true)
->select();
SELECT * FROM `user` WHERE `name` LIKE '张三%'
2. 搜索器方法的三个参数 searchNameAttr($query, $value, $data)
- $query:
think\db\Query
对象,用于链接操作 - $value:withSearch() 第二个参数中当前搜索器字段对应的值
- $data:withSearch() 第二个参数的值
可以直接在搜索器方法中打印参数,看看到底是个啥
站长源码网<?php
namespace app\index\model;
class User extends \think\Model
{
public function searchNameAttr($query, $value, $data)
{
halt($query, $value, $data);
$query->where('name','like', $value . '%');
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!