Thinkphp6模型事件类似于Vue的钩子函数,方便我们在增、删、查、改这个时间段进行操作
模型事件
首先,从手册上,我们可以知道模型支持以下事件:
| 事件 | 描述 | 事件方法名 |
|---|---|---|
| after_read | 查询后 | onAfterRead |
| before_insert | 新增前 | onBeforeInsert |
| after_insert | 新增后 | onAfterInsert |
| before_update | 更新前 | onBeforeUpdate |
| after_update | 更新后 | onAfterUpdate |
| before_write | 写入前 | onBeforeWrite |
| after_write | 写入后 | onAfterWrite |
| before_delete | 删除前 | onBeforeDelete |
| after_delete | 删除后 | onAfterDelete |
| before_restore | 恢复前 | onBeforeRestore |
| after_restore | 恢复后 | onAfterRestore |
建立模型
为了了解每个事件的触发条件,我们先建立以下模型:
<?php
namespace appmodel;
use thinkModel;
class Article extends Model
{
public static function onAfterRead($user) {
// 查询后:每次执行就查询一条数据
dump('查询后');
// halt($user);
}
public static function onBeforeInsert($user) {
// 新增前:获取的新增数据,还没新增
dump('新增前');
// halt($user->toArray());
}
public static function onAfterInsert($user) {
// 新增后:获取的新增数据,已经新增数据
dump('新增后');
// halt($user->toArray());
}
public static function onBeforeUpdate($user) {
// 更新前:获取的更新数据,还没更新数据
dump('更新前');
// halt($user->toArray());
}
public static function onAfterUpdate($user) {
// 更新后:获取的更新数据,已经更新数据
dump('更新后');
// halt($user->toArray());
}
public static function onBeforeWrite($user) {
// 写入前:获取的当前数据,还没新增、更新
dump('写入前');
// halt($user->toArray());
}
public static function onAfterWrite($user) {
// 写入后:获取的当前数据
dump('写入后');
// halt($user->toArray());
}
public static function onBeforeDelete($user) {
// 删除前:获取的删除前数据,还没删除
dump('删除前');
// halt($user->toArray());
}
public static function onAfterDelete($user) {
// 删除后:获取的删除数据,已经删除
dump('删除后');
}
public static function onBeforeRestore($user) {
dump('恢复前');
}
public static function onAfterRestore($user) {
dump('恢复后');
}
}
测试代码
然后通过以下代码去操作数据库:
public function demo9(Article $model){
// 查询后:数据有多少条onAfterRead就执行多少次,我的数据有9条,所有执行9次
$model::select();
//写入前、新增前、新增后、写入后
$model::create([
'title'=>'test1',
'content'=>'111111111111111',
]);
//写入前、新增前、新增后、写入后
$model->save([
'title'=>'test2',
'content'=>'22222222222',
]);
//查询后、写入前、更新前、写入后、更新后
$art = $model::find(7);
$art->save([
'title'=>'test3',
'content'=>'33333333333333',
]);
//写入前、更新前、更新后、写入后
$model->update([
'id'=>8,
'title'=>'test4',
'content'=>'4444444444444',
]);
//没有触发
$model::where('id',11)->delete();
//没有触发
$model->insert([
'title'=>'test1',
'content'=>'111111111111',
]);
//没有触发
$model->where('id',8)->update([
'title'=>'test4',
'content'=>'4444444444444',
]);
//查询后、删除前、删除后
$art = $model::find(9);
$art->delete();
//查询后、删除前、删除后
$model::destroy(13);
}
如果你想获取以前的数据进行对比,使用getOrigin:
public static function onAfterUpdate($user) {
$origin = $user->getOrigin("category");//以前数据
$category = $user['category'];//当前的数据
if ($origin != $category) {
//操作
}
}
总结
create()
模型创建数据方法,会触发写入前、新增前、新增后、写入后。使用模型的save()和saveAll()来新增方法也会触发这几个事件。
insert()
insert()是Db类的方法,不是模型方法,不会触发模型事件。
update()
update()模型方法,写入前、更新前、更新后、写入后。
如果是直接使用条件更新,则不会触发模型事件。因为直接使用条件更新,这时候的update()方法不是模型方法。
save()
使用模型的save()方法来更新数据,会触发写入前、更新前、更新后、写入后事件。
delete()
如果是使用模型方法查询出来数据,然后再删除数据,则会触发删除前、删除后事件。
如果是直接使用条件删除,则不会触发模型事件。因为直接使用条件删除,这时候的delete()方法不是模型方法。
find()
该查询方法会触发查询后事件
destroy()
该删除数据方法会触发查询后、删除前、删除后。所以,该方法是先查询出数据,然后再删除该数据。
restore()
该软删除恢复方法会触发恢复前、恢复后方法
