广告位 |
thinkphp查询范围
2021年9月25日 11:14编程 > 1894人已围观
简介 可以对模型的查询和写入操作进行封装,例如:在查询的时候可以如下使用: // 查询email包含thinkphp和分数大于80的用户User::email('thinkphp')->score(80)->select(); 可以直接使用闭包函数进行查询,例如:...
可以对模型的查询和写入操作进行封装,例如:
<?php namespace app\model;use think\Model;class User extends Model{ public function scopeThinkphp($query) { $query->where('name','thinkphp')->field('id,name'); } public function scopeAge($query) { $query->where('age','>',20)->limit(10); } }
就可以进行下面的条件查询:
// 查找name为thinkphp的用户User::scope('thinkphp')->find();// 查找年龄大于20的10个用户User::scope('age')->select();// 查找name为thinkphp的用户并且年龄大于20的10个用户User::scope('thinkphp,age')->select();
查询范围的方法可以定义额外的参数,例如User模型类定义如下:
<?php namespace app\model;use think\Model;class User extends Model{ public function scopeEmail($query, $email) { $query->where('email', 'like', '%' . $email . '%'); } public function scopeScore($query, $score) { $query->where('score', '>', $score); } }
在查询的时候可以如下使用:
// 查询email包含thinkphp和分数大于80的用户User::email('thinkphp')->score(80)->select();
可以直接使用闭包函数进行查询,例如:
User::scope(function($query){ $query->where('age','>',20)->limit(10);})->select();
使用查询范围后,只能使用
find
或者select
查询。
全局查询范围
支持在模型里面设置globalScope
属性,定义全局的查询范围
<?php namespace app\model;use think\Model;class User extends Model{ // 定义全局的查询范围 protected $globalScope = ['status']; public function scopeStatus($query) { $query->where('status',1); }}
然后,执行下面的代码:
$user = User::find(1);
最终的查询条件会是
status = 1 AND id = 1
如果需要动态关闭所有的全局查询范围,可以使用:
// 关闭全局查询范围User::withoutGlobalScope()->select();
可以使用withoutGlobalScope
方法动态关闭部分全局查询范围。
User::withoutGlobalScope(['status'])->select();
上一篇: thinkphp数据模型获取器
下一篇: thinkphp模型数据的更新操作
广告位 |
相关文章
随机图文
-
保持一颗平常心,快乐做事,开心做人
懦弱强食的社会,当你眼红别人的进步和成就时,保持一颗平常心,每一个美好的背后都有无尽的努力,他们付出了,那是他们应得的回报。嫉妒拉不近你和他(她)的差距,徒使你蹉跎了岁月,颓废了人生。... -
网红掉入资本“盘丝洞”
9月23号,李子柒出现在中国农民丰收活动现场,并被聘为四川农耕文化形象大使,安静坐在前排,视频依旧未更新,助理口中的“现实问题”似乎也还未完全解决,网友便给贴上了“深山无知少女与资本老狐狸的缠斗”的标签。... -
django2集成DjangoUeditor富文本编辑器
富文本编辑器,在web开发中可以说是不可缺少的。django并没有自带富文本编辑器,因此我们需要自己集成,在这里推荐大家使用DjangoUeditor,因为DjangoUeditor封装了我们需要的一些功能如文件上传、在后台和前台一起使用等,非常方便。... -
短视频行业开起“收徒做任务”模式,能战抖音、斗快手吗?
百度正用趣头条的模式「批量生产」属于自己的抖音。 马化腾没做成的短视频梦,李彦宏正在接力。但趣头条的噩梦,百度可能也要继承。...