- 浏览: 803753 次
- 性别:
- 来自: 南京
文章分类
最新评论
-
xieye:
jetty插件有好几个版本,1.6,1.7,1.8
我选的是用 ...
tapestry入门(翻译)3 导入项目到eclipse -
xieye:
还有,
注:第2部分时,需要先安装jetty,我自己在安装过程 ...
tapestry入门(翻译)3 导入项目到eclipse -
xieye:
说明一下:实际使用中,导入时我并没有错误。2、我把eclips ...
tapestry入门(翻译)3 导入项目到eclipse -
xieye:
其实还是有一些先决条件的。1是外部环境,2是进步是阶段性的(意 ...
(转载文章)如何愉悦起来:一位精神治疗师的见解 -
mandy_yanzi:
我都已经饿7天了坚持为了我的衣衣
身体健康的问题
我的Eloquent单独使用系列文章
php的db类库Eloquent单独使用系列(1)
php的db类库Eloquent单独使用系列(2) - 分页
php的db类库Eloquent单独使用系列(3) - sql日志
php的db类库Eloquent单独使用系列(4)- 事件监听
php的db类库Eloquent单独使用系列(5)- 模型转数组
php的db类库Eloquent单独使用系列(6)- 一对一关联
php的db类库Eloquent单独使用系列(7)- 一对多关联
php的db类库Eloquent单独使用系列(8)- 多对多关联
php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身
php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多
php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性
php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2
本系列文章的目的就是脱离laravel环境使用Eloquent,因为它好用。
本系列文章所有代码均测试通过。Eloquent版本:5.4.27
本文的目的是使用事件,即钩子函数,用于保存前后,修改数据模型前后,删除前后。
下面的代码假定使用了一个表test2。
主要是4个文件,名字都可以自己改。路径也可以自己改,只要改namespace即可。
1)User是模型文件,里面啥都没有,从我目前测试结果看,也无法在类里面写监听。
2)程序主文件。Ill.php
3)sql日志事件文件。SqlListener
4)User观察者类。需被手动注册到User类上面。
文件层次:
app
- control
- Ill.php
- model
- SqlListener.php
- User.php
- UserObserver.php
模型文件User.php
观察者类UserObserver.php
sql日志文件
主程序
下面是浏览器输出结果
总结:总的来说,还是很好用的。但是,手动注册观察者的代码需要封装到函数里,在php应用程序的公共起始文件里被调用。
php的db类库Eloquent单独使用系列(1)
php的db类库Eloquent单独使用系列(2) - 分页
php的db类库Eloquent单独使用系列(3) - sql日志
php的db类库Eloquent单独使用系列(4)- 事件监听
php的db类库Eloquent单独使用系列(5)- 模型转数组
php的db类库Eloquent单独使用系列(6)- 一对一关联
php的db类库Eloquent单独使用系列(7)- 一对多关联
php的db类库Eloquent单独使用系列(8)- 多对多关联
php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身
php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多
php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性
php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2
本系列文章的目的就是脱离laravel环境使用Eloquent,因为它好用。
本系列文章所有代码均测试通过。Eloquent版本:5.4.27
本文的目的是使用事件,即钩子函数,用于保存前后,修改数据模型前后,删除前后。
下面的代码假定使用了一个表test2。
主要是4个文件,名字都可以自己改。路径也可以自己改,只要改namespace即可。
1)User是模型文件,里面啥都没有,从我目前测试结果看,也无法在类里面写监听。
2)程序主文件。Ill.php
3)sql日志事件文件。SqlListener
4)User观察者类。需被手动注册到User类上面。
文件层次:
app
- control
- Ill.php
- model
- SqlListener.php
- User.php
- UserObserver.php
模型文件User.php
<?php namespace app\model; use \Illuminate\Database\Eloquent\Model; /** * User模型类 */ class User extends Model { protected $table = 'test2'; public $timestamps = false; // 这是我自己添加的,记录错误信息 private $errinfo=''; public function set_errinfo($info) { $this->errinfo = $info; } public function get_errinfo() { return $this->errinfo ; } }
观察者类UserObserver.php
<?php namespace app\model; use app\model\User; /** * User类的观察者。放置了各种钩子函数 * */ class UserObserver { /** * 添加用户钩子 * * 特别点在于,前置类型的钩子,如返回假则后面不执行。 * 后缀是ing的钩子函数,就是前置类型的钩子。如updating,deleting等。共5个。 * * @param User $user * @return void */ public function creating(User $user) { if ( strlen( $user->user) <2 ) { $user->set_errinfo("creating: 用户名至少两个字符"); return false; } } /** * 添加用户钩子 * * @param User $user * @return void */ public function created(User $user) { echo "<b>in UserObserver.created:". $user->id ."</b><br>"; } /** * 修改用户钩子 * * @param User $user * @return void */ public function updated(User $user) { echo "<b>in UserObserver.updated:". $user->id ."</b><br>"; } }
sql日志文件
<?php namespace app\model; use Illuminate\Events\Dispatcher; use Illuminate\Database\Events\QueryExecuted; /** * sql监听类,记录sql日志。 */ class SqlListener extends Dispatcher { /** * 注意:就改这个函数。也可以记录到文件日志里。 * * @param string|object $event * @param mixed $payload * @param bool $halt * @return array|null */ public function dispatch($event, $payload = [], $halt = false) { if ($event instanceof QueryExecuted) { $sql=$event->sql; if ($event->bindings) { foreach($event->bindings as $v) { $sql = preg_replace('/\\?/', "'". addslashes( $v)."'", $sql,1); } } echo "log: ".$sql."<br>"; } } }
主程序
<?php namespace app\control; use Illuminate\Database\Capsule\Manager; use Illuminate\Events\Dispatcher; use app\model\User; use app\model\SqlListener; class Ill { /** * 主程序。 */ public function hook() { $capsule = new Manager (); $capsule->addConnection ( [ 'driver' => 'mysql', 'host' => '127.0.0.1', 'database' => 'test1', 'username' => 'root', 'password' => 'root', 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '' ] ); $capsule->setAsGlobal (); $capsule->bootEloquent (); // 设置sql日志监听 $capsule->setEventDispatcher ( new SqlListener () ); // User模型类加钩子 User::setEventDispatcher ( new Dispatcher () ); User::observe ( \app\model\UserObserver::class ); // 这句话单纯测试log $users = $capsule::select ( 'SELECT * FROM test2 limit 1' ); // 下面几句测log + 钩子 $user = new User (); $user->user = '11'; $result = $user->save (); // 新模型添加 $user->user = '22'; $result = $user->save (); // 已经不是新模型,是已存在模型,所以是修改。 $user = new User (); $user->user = '3'; // 故意填写过短的用户名 $result = $user->save (); // 注意这里!因为创建模型前置函数creating返回假。 if (! $result) { echo $user->get_errinfo () . "<br>"; } echo 'all ok!'; } }
下面是浏览器输出结果
log: SELECT * FROM test2 limit 1 log: insert into `test2` (`user`) values ('11') in UserObserver.created:120 log: update `test2` set `user` = '22' where `id` = '120' in UserObserver.updated:120 creating: 用户名至少两个字符 all ok!
总结:总的来说,还是很好用的。但是,手动注册观察者的代码需要封装到函数里,在php应用程序的公共起始文件里被调用。
发表评论
-
召唤神龙 - 安装 centos 8, php 8, mysql 8, laravel 8 的整套 php 运行环境
2020-11-27 16:26 548本文编写时间:2020-11-27 传说集齐龙珠可以召唤神 ... -
centos8 使用阿里镜像快速安装php7.4套件
2020-11-15 00:48 659centos8 使用阿里镜像快速安装php7.4套件 本文只 ... -
centos7 使用阿里镜像快速安装php7.4套件
2020-11-15 00:32 995本文只考虑centos7 今日 2020-11-16 rem ... -
composer常用命令
2020-11-05 14:46 991列出当前全局配置 composer config -l -g ... -
期待centos8+php8 + mysql8 + laravel8,8888
2020-10-29 19:24 376期待centos8+php8 + mysql8 目前主要使用 ... -
ubuntu 安装 php7.4以及各类插件
2020-10-24 13:20 890ubuntu 安装 php7.4以及各类插件 安装系统 最近 ... -
宝塔定义站点
2020-02-24 10:41 2宝塔定义站点。 1111111111111111111111 ... -
让php-fpm以root账号运行
2020-02-19 21:41 689一般来说,我们没有这种需求,但是当需要时, 可以让php-fp ... -
将代码部署到coding.net
2020-01-10 14:20 536coding.net 是一个git仓库,有免费有收费。 首先 ... -
php部署工具deployer技巧 - vendor目录创建
2020-01-06 12:06 801deployer是个好东西,可是每次都composer ,其实 ... -
自定义redis多个实例
2020-01-04 01:17 575假如多个项目部署到同一台服务器,有时会被redis的各项目前缀 ... -
推荐使用php的部署工具 deployer
2020-01-03 16:48 804php部署代码可以使用 https://deployer.or ... -
使用composer 类库 cachetool 清除opcache 的缓存
2020-01-03 16:38 872php的生产服务器上,需要把opche打开。 但有时,会被缓 ... -
laravel容器学习体会
2019-12-31 15:11 565根据文档与实测结果 假设我在app下建一个Services目 ... -
phalcon 自定义超强日志类
2019-12-18 10:00 758phalcon自带的日志文件类,有两个麻烦之处。 1、路径不能 ... -
自定义后台的使用
2019-12-18 05:22 359如果自己写后台,保存用户的表单请求值 所有的情况如下: 1 ... -
phalcon 自定义事件使用的多种方式
2019-12-16 20:43 709方法1:官方文档的方式。 这是控制器: public ... -
phalcon对控制器返回值的使用以输出json
2019-12-16 19:17 726在phalcon里,控制器的Action的方法的返回值没啥用。 ... -
phalcon数据库DB使用实例
2019-12-12 17:12 586整理了一下phalcon的db使用,写了个demo。 ... -
php-redis5.0降级成php-redis4.3
2019-08-22 00:01 832最新版本的php的redis插件,版本是5.0 但是可能会有 ...
相关推荐
Laravel开发-eloquent-uuid-for-key 用于Laravel雄辩的Uuid4键
Laravel开发-eloquent-extended-cast-model .zip
Laravel开发-eloquent-single-state-marking-store 一个雄辩的支持,单一状态标记存储symfony的工作流程。
Laravel开发-eloquent-log-lazy-loading 记录(或禁用)雄辩的延迟加载关系。
Laravel开发-eloquent-single-table-inheritance 单表继承(Sti)作为Laravel雄辩模型的特征实现
Laravel开发-eloquent-extended-cast-model 这个库帮助您制作更高级的演员表到雄辩的模型。
ROS是一个用于在不同进程间匿名的发布、订阅、传递信息的中间件。 ROS2系统的核心部分是ROS网络(ROS Graph)。ROS网络是指在ROS系统中不同的节点间相互通信的连接关系。 ROS Graph这里翻译成了ROS网络,因为我觉得...
应用使用邮递员,失眠等用法$ git clone https://github.com/DanielArturoAlejoAlvarez/Eloquent-Relations-Laravel-7-and-MySQL[NAME APP]$ composer install$ copy .env.example .env$ php artisan key:generate$ ...
Laravel开发-eloquent-state-machine 雄辩状态机
Laravel开发-eloquent-model-generator 自动从Laravel5项目中的数据库生成所有雄辩的模型。
$ git clone https://github.com/DanielArturoAlejoAlvarez/Eloquent-ORM-Laravel-8.5-Relationships-Advanced[NAME APP] $ composer install $ copy .env.example .env $ php artisan key:generate $ php artisan ...
eloquent-javascript--ch4-exercises eloquent javascript 第 4 章的练习
Laravel开发-eloquent-mongodb-repository 雄辩的MongoDB存储库实现
composer require mpyw/eloquent-has-by-non-dependent-subquery 动机 假设您具有以下关系: class Post extends Model { use SoftDeletes ; public function comments (): HasMany { return $ this -> has...
Laracasts advanced-eloquent 视频课程全集-----下载
Laravel开发-eloquent-value-object 幼虫雄辩的值对象。
一本关于JavaScript,编程和数字奇迹的书。
Laravel开发-eloquent-search-map 轻松搜索模型的雄辩搜索宏
Laravel开发-eloquent-postgres-uuids 有助于在Postgres数据库中使用UUID作为主键的大型雄辩特征。
composer require krlove/eloquent-model-generator --dev 步骤2.注册GeneratorServiceProvider : 'providers' => [ // ... Krlove \ EloquentModelGenerator \ Provider \ GeneratorServiceProvider ::class, ...