广告位 |
thinkphp查询范围
2021年9月25日 11:14编程 > 2261人已围观
简介 可以对模型的查询和写入操作进行封装,例如:在查询的时候可以如下使用: // 查询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模型数据的更新操作
广告位 |
相关文章
随机图文
-
django如何给上传的图片重命名
django如何给上传的图片重命名(给上传文件重命名) 1、先在你项目中添加一个文件夹如:system 在文件夹下添加__init__.py 和storage.py文件,并在storage.py中添加如下代码:... -
保持一颗平常心,快乐做事,开心做人
懦弱强食的社会,当你眼红别人的进步和成就时,保持一颗平常心,每一个美好的背后都有无尽的努力,他们付出了,那是他们应得的回报。嫉妒拉不近你和他(她)的差距,徒使你蹉跎了岁月,颓废了人生。... -
平面设计的过程
平面设计的过程是有计划有步骤的渐进式不断完善的过程,设计的成功与否很大程度上取决于理念是否准确,考虑是否完善。设计之美永无止境,完善取决于态度。... -
感谢生命中的那些过客
生命中总有一些来来往往的人,就像我们走路时马路上的那些过客,有与我们背道而行的,也有与我们走向同一个方向的。与我们背道而行的,也许我们转瞬即忘;也许,在生命中的某一天里,我们也还会偶尔地想起一下而已——他们在我们身后,已经越来越远。即使因为某些原因又重新折回来,可是因为相隔的太远,再努力恐怕也无法追得上。...