如何在 ThinkPHP 中整合 Laravel Eloquent ORM

前言

以前维护的旧项目采用的 ThinkPHP 3.2,后面学习了 Laravel 后,以为 TP 的 Model 功能没有 Laravel 强大和方便,并想把 Laravel 里的 Eloquent 用在 TP 里。php

好在 Laravel 的 ORM 是独立成包的,能够用于符合要求的其余 PHP 系统中。html

整合

要使用的是 illuminate/databasegit

  • 安装 illuminate/database
    根据本身使用的 PHP 版本,经过 composer 安装对应的 illuminate/database 版本,例如github

composer require illuminate/database:5.3.*
  • 接入到 TP 中
    在 ThinkPHPLibraryThinkThink.class.php 文件中的 start方法的最后一行的 App::run(); 上方添加以下代码:数据库

$capsule = new \Illuminate\Database\Capsule\Manager;
$capsule->addConnection([
            'driver'    => C('DB_TYPE'),
            'host'      => C('DB_HOST'),
            'database'  => C('DB_NAME'),
            'username'  => C('DB_USER'),
            'password'  => C('DB_PWD'),
            'charset'   => C('DB_CHARSET'),
            'collation' => C('DB_COLLATION'),
            'prefix'    => C('DB_PREFIX'),
]);
$capsule->setAsGlobal();
$capsule->bootEloquent();
  • 解决 E 方法冲突
    illuminate/database 的 vendorilluminatesupporthelpers.php 方法中存在一个方法composer

/**
     * Escape HTML special characters in a string.
     *
     * @param  \Illuminate\Contracts\Support\Htmlable|string  $value
     * @return string
     */
 function e($value)
    {
        if ($value instanceof Htmlable) {
            return $value->toHtml();
        }
    
        return htmlspecialchars($value, ENT_QUOTES, 'UTF-8', false);
    }

与 TP 的 E 方法冲突。ide

/**
 * 抛出异常处理
 * @param string $msg 异常消息
 * @param integer $code 异常代码 默认为0
 * @throws Think\Exception
 * @return void
 */
function E($msg, $code=0) {
    throw new Think\Exception($msg, $code);
}

我选择注释了 illuminate/database 的方法,搜索后发现没有其余地方用到这个方法,故注释。学习

完成后就能够愉快地使用 Laravel 的 ORM 来 coding 了。ui

tips

  • TP 的数据库通常不会有 created_at 和 updated_at 字段,而 illuminate/database 会自动维护这两个字段,因此须要在建立的 Model 文件里,添加以下代码spa

public $timestamps = false;

本文排版遵守 中文文案排版指北(简体中文版)

Enjoy it !若是以为文章对你有用,能够请我喝杯咖啡~

相关文章
相关标签/搜索