`
xieye
  • 浏览: 830856 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

php的db类库Eloquent单独使用系列(3) - sql日志

    博客分类:
  • PHP
阅读更多
我的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



安装同前,就不说了。
本文的目的是单独使用eloquent,脱离laravel环境使用,要求能打印sql日志。不想用laravel,但又想用eloquent。

下面的代码假定使用了一个表test2。

主要是3个文件,名字都可以自己改。路径也可以自己改,只要改namespace即可。
1)User是模型文件,里面啥都没有。
2)程序主文件。Ill.php
3)监听事件文件。SqlListener

模型文件User.php
<?php
namespace app\model;
class User extends \Illuminate\Database\Eloquent\Model 
{
    protected $table = 'test2';
    public $timestamps = false;
}


监听文件 SqlListener.php
<?php
namespace app\model;
class SqlListener implements \Illuminate\Contracts\Events\Dispatcher 
{
    /**
     * Dispatch an event and call the listeners.
     * 
     * 注意:就改这个函数。也可以记录到文件日志里。
     *
     * @param  string|object  $event
     * @param  mixed  $payload
     * @param  bool  $halt
     * @return array|null
     */
    public function dispatch($event, $payload = [], $halt = false)
    {
        if ($event instanceof  \Illuminate\Database\Events\QueryExecuted) {
            $sql=$event->sql;
            if ($event->bindings) {
                foreach($event->bindings as $v) {
                    $sql = preg_replace('/\\?/', "'". addslashes( $v)."'", $sql,1);
                }
            }
            echo $sql."<br>";
        }
    }
    
    public function listen($events, $listener){}
    public function hasListeners($eventName){}
    public function subscribe($subscriber){}
    public function until($event, $payload = []){}
    public function push($event, $payload = []){}
    public function flush($event){}
    public function forget($event){}
    public function forgetPushed(){}
}


程序主文件,能够记录执行的sql代码,调试时真的很有实用价值!
<?php
namespace app\control;
use \Illuminate\Database\Capsule\Manager as Capsule;
use app\model\User;
class Ill 
{
   public function logdemo()
   {
       $capsule = new Capsule;
       $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 \app\model\SqlListener()  );
       //下面是两种不同类型的sql操作,第一种是db门面,第2种使用了orm。
       $users = $capsule::select('SELECT * FROM test2 limit 1');
       $user = User::find(1);
   }
}


下面是浏览器显示效果。
SELECT * FROM test2 limit 1
select * from `test2` where `test2`.`id` = '1' limit 1

0
1
分享到:
评论

相关推荐

    Laravel开发-eloquent-extended-cast-model

    Eloquent-Extended-Cast-Model 是一个扩展库,它增强了Eloquent模型的特性,允许开发者定义自定义的类型转换,从而能够更加灵活地管理和操作数据。 Eloquent ORM的核心概念包括模型(Model)、迁移(Migration)、...

    Laravel开发-eloquent-uuid-for-key

    1. **安装扩展包**:通常我们可以使用`spatie/laravel-eloquent-has-many-deep`这个扩展包,它为Eloquent提供了对UUID的支持。通过Composer安装: ``` composer require spatie/laravel-eloquent-has-many-deep `...

    Laravel开发-laravel-sql-logger

    默认情况下,Laravel不会自动记录每个SQL查询,但可以通过开启`DB::enableQueryLog()`来开启查询日志,然后通过`DB::getQueryLog()`获取已执行的查询列表。然而,这种方式可能不够全面,尤其是在大型项目中,我们...

    Laravel开发-eloquent-single-state-marking-store

    "Laravel开发-eloquent-single-state-marking-store"是一个专为Laravel设计的扩展,旨在支持单一状态标记存储,其灵感来源于Symfony的工作流程组件。这个项目的目标是帮助开发者更好地管理和跟踪对象的状态,特别是...

    Laravel开发-eloquent-log-lazy-loading

    只有在尝试访问关联属性时,Eloquent才会执行额外的SQL查询去获取关联数据。这样可以避免不必要的数据传输,提高应用程序的效率。 2. 如何启用延迟加载: 默认情况下,Eloquent模型会自动使用延迟加载。例如,如果...

    Laravel开发-eloquent-extended-cast-model .zip

    这个压缩包“Laravel开发-eloquent-extended-cast-model .zip”很可能包含了一些关于如何扩展Eloquent模型的自定义类型转换(casts)的教程或示例代码。 Eloquent的模型类与数据库表一一对应,每个模型实例代表表中...

    Laravel开发-sql-logging

    你可以根据需求选择合适的驱动来存储SQL日志,例如,你可以将日志保存到单独的文件中,或者设置日志按天分割,甚至将日志发送到Slack频道。 描述中提到的“Laravel 5包”可能是指一个第三方扩展,用于增强或自定义...

    Laravel开发-sql-dumper

    3. **学习与理解**:对于新手开发者,观察SQL Dumper中的查询可以帮助理解Laravel Eloquent ORM是如何生成SQL的。 在`sql-dumper-master`这个压缩包中,可能包含了实现自定义SQL Dumper的代码,或者是对Laravel ...

    Laravel开发-eloquent-single-table-inheritance

    在Laravel框架中,Eloquent ORM(对象关系映射)是其强大且优雅的数据操作工具。Eloquent提供了许多高级特性,其中包括单表继承(Single Table Inheritance,STI)。本教程将深入探讨如何在Laravel项目中利用...

    Laravel开发-laravel-sqlanywhere

    使用Eloquent,我们可以创建一个对应于SQL Anywhere表的模型。例如,如果我们有一个`users`表,可以创建一个`User`模型,并定义其与表的关系: ```php use Illuminate\Database\Eloquent\Model; class User ...

    ros2-eloquent-20191122-windows-release-amd64.zip

    ROS是一个用于在不同进程间匿名的发布、订阅、传递信息的中间件。 ROS2系统的核心部分是ROS网络(ROS Graph)。ROS网络是指在ROS系统中不同的节点间相互通信的连接关系。 ROS Graph这里翻译成了ROS网络,因为我觉得...

    Laravel开发-eloquent-model-generator

    使用Eloquent-Model-Generator的步骤可能包括以下几点: 1. 安装:首先,你需要将该工具通过Composer添加到你的Laravel项目的依赖中,通常使用`composer require`命令。 2. 配置:配置文件中,你需要指定数据库连接...

    Laravel开发-laravel-dblib-odbc-sqlserver

    在本文中,我们将深入探讨如何在 Laravel 开发环境中配置和使用 `laravel-dblib-odbc-sqlserver` 驱动,以便与 Microsoft SQL Server 数据库进行交互。Laravel 是一个流行的PHP框架,它提供了优雅的工具来构建高质量...

    php一些比较常用类库及例子

    通过PDO,你可以使用预处理语句,防止SQL注入攻击。例如: ```php $db = new PDO('mysql:host=localhost;dbname=test', $user, $pass); $stmt = $db-&gt;prepare("INSERT INTO users (name, email) VALUES (?, ?)");...

    Laravel开发-sqlrelay

    配置好后,你可以像使用其他数据库一样在 Laravel 应用中使用 SQL Relay 连接。Laravel 的 Eloquent ORM 和 Query Builder 都可以无缝地工作。例如,创建一个新的模型: ```php use Illuminate\Database\Eloquent\...

    Laravel开发-laravel-eloquent-mysqli

    总之,`laravel-eloquent-mysqli` 项目旨在帮助开发者了解和实践在 Laravel 中使用 mysqli 驱动进行数据库操作,这对于那些需要充分利用 MySQL 扩展特性的项目来说,是一个有价值的资源。在实际开发中,根据项目需求...

    Laravel开发-laravel5-sqlanywhere

    在本文中,我们将深入探讨如何在Laravel框架中使用SAP SQL Anywhere数据库。Laravel是一个流行的PHP框架,以其优雅的语法和强大的功能而受到开发者喜爱。SQL Anywhere是SAP公司提供的一款轻量级、可扩展的数据库系统...

    Eloquent-Relationships-Advanced-Laravel-7-and-MySQL:Laravel和MySQL开发软件

    应用使用邮递员,失眠等用法$ git clone https://github.com/DanielArturoAlejoAlvarez/Eloquent-Relations-Laravel-7-and-MySQL[NAME APP]$ composer install$ copy .env.example .env$ php artisan key:generate$ ...

Global site tag (gtag.js) - Google Analytics