广告位 |
thinkphp查询范围
2021年9月25日 11:14编程 > 1895人已围观
简介 可以对模型的查询和写入操作进行封装,例如:在查询的时候可以如下使用: // 查询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模型数据的更新操作
广告位 |
相关文章
随机图文
-
小心“熬夜水”里淹死人
透明复古的玻璃瓶,配料表里满是“大补”,还能看到一整根人参……继“啤酒枸杞”“喝可乐放党参”等“创意”养生方法之后,近来一种由中药制作的“熬夜水”在奶茶界异军突起,它号称能让年轻人在熬夜后迅速恢复元气。... -
thinkphp自动写入创建和更新的时间戳
系统支持自动写入创建和更新的时间戳字段(默认关闭),有两种方式配置支持。 第一种方式是全局开启,在数据库配置文件中进行设置:... -
做抖音心得……
他明白了为何古人皆要戒酒消愁,他明白为何达官显贵皆要放浪青楼。也许本是他的错,那年年少,错把痴情真心付之东流。... -
商家增长“拐点”在哪里
商品与消费者之间,有着“一体两翼”的关系。“一体”是两者链路之间需要有运营桥梁,而“两翼”便是数据和流量,这就需要线下商家在运营中一手抓数据、一手抓流量。...