ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
[TOC] ## 对模型的查询和写入进行封装`scope` ~~~ namespace app\index\model; use think\Model; class User extends Model { protected function scopeThinkphp($query) { $query->where('name','thinkphp')->field('id,name'); } protected 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::scope(function($query){ $query->where('age','>',20)->limit(10); })->select(); ~~~ 支持传入参数 支持动态调用 ~~~ $user->thinkphp()->get(); ~~~ ## 删除数据 1. 根据主键调用静态方法 ~~~ User::destroy(1); // 支持批量删除多个数据 User::destroy('1,2,3'); User::destroy([1,2,3]); ~~~ 2. 条件删除 ~~~ User::destroy(['status' => 0]); ~~~ 3. 闭包删除 ~~~ User::destroy(function($query){ $query->where('id','>',10); }); ~~~ 4. 根据查询条件删除 ~~~ User::where('id','>',10)->delete(); ~~~ 5. 根据模型删除 ~~~ $user = User::get(1); $user->delete(); ~~~