gpt4 book ai didi

php - 如何在 PHP 5.3.x 的其他框架中使用 Illuminate Database Query Builder 和 Eloquent

转载 作者:行者123 更新时间:2023-12-02 17:10:41 28 4
gpt4 key购买 nike

我过去用 Laravel 做过几个项目,但现在我需要一些非常轻的项目,所以我选择使用 Slim,它非常适合我的需要,我想要 Laravel 的 Eloquent ORM 和查询生成器,现在不能没有它:)现在我设法让这一切与 Composer 一起工作,使用泰勒在他的 GitHub 上显示的信息,复制他的代码

use Illuminate\Database\Capsule\Manager as Capsule;

$capsule = new Capsule;

$capsule->addConnection([
'driver' => 'mysql',
'host' => 'localhost',
'database' => '',
'username' => '',
'password' => '',
'charset' => 'utf8',
'collation' => 'utf8_unicode_ci',
'prefix' => '',
]);

// Set the event dispatcher used by Eloquent models... (optional)
use Illuminate\Events\Dispatcher;
use Illuminate\Container\Container;
$capsule->setEventDispatcher(new Dispatcher(new Container));

// Set the cache manager instance used by connections... (optional)
$capsule->setCacheManager(...);

// Make this Capsule instance available globally via static methods... (optional)
$capsule->setAsGlobal();

// Setup the Eloquent ORM... (optional; unless you've used setEventDispatcher())
$capsule->bootEloquent();

这在我的本地开发(PHP 5.4.x)上运行得很好,但是当我把它放在我的服务器上PHP 5.3.x时,它就不再工作了:( 现在我看到 1问题是我们不能像这样使用匿名数组 [] ,而是应该以 array() 的旧方式编写,即在 addConnection( array($settings)) 太棒了,现在更进一步了...但是在它似乎在 $capsule->setEventDispatcher() 内部崩溃之后,我的日志上没有日志服务器(我只是通过 var_dump() 到处找到的),它只是一个 NAS,我什至不想花几个小时来了解如何启用它。但有趣的是我有一个 Laravel 4 个项目正在使用它......那么为什么只构建它的一部分 Illuminate\Database 不起作用呢?我还找到了另一段代码,使 Eloquent ORM 在 PHP 5.3.x 中工作

$settings = array(
'driver' => '',
'host' => '127.0.0.1',
'database' => '',
'username' => '',
'password' => '',
'charset' => "utf8",
'collation' => 'utf8_general_ci',
'prefix' => ''
);


// Bootstrap Eloquent ORM
$connFactory = new \Illuminate\Database\Connectors\ConnectionFactory(new Illuminate\Container\Container);
$conn = $connFactory->make($settings);
$resolver = new \Illuminate\Database\ConnectionResolver();
$resolver->addConnection('default', $conn);
$resolver->setDefaultConnection('default');
\Illuminate\Database\Eloquent\Model::setConnectionResolver($resolver);

但是如果我使用这段代码,顺便说一下,这对模型来说很好。我需要使用 $conn->table('...')... 而不是 DB::table(....) 的 Facade 简单方法这就是我想要的,你会说为什么它很重要?好吧,如果我将来想转换为 Laravel 怎么办...我必须将所有 $conn-> 更改为 DB:: 所以我宁愿这样做第一次就对了。如果有人知道如何在第二段代码上创建 Facade,我也会很高兴...感谢您的帮助。

最佳答案

我也在使用 Capsule 和 Slim。首先,确保您使用的是 Illuminate/Capsule 4.1.* 版本。当 4.2 发布时,最大的变化之一是 PHP 5.4 成为所需的最低版本。 4.1 仍可与 PHP 5.3 配合使用。

现在,如果你已经这样做了,但仍然遇到问题,这就是我向 Slim 的 IoC 容器注册胶囊的方法:

$app->container->singleton('capsule', function() use ($config) {
$capsule = new Illuminate\Database\Capsule\Manager;

$capsule->setFetchMode(PDO::FETCH_OBJ);
$capsule->addConnection($config['database']);
$capsule->bootEloquent();

return $capsule->getConnection();
});

注意对 getConnection() 的调用。这是必要的,因为 Capsule 全局尚未注册。

编辑:另请注意对 setFetchMode 的调用。当在 Laravel 中使用 Fluent 时,查询返回 stdClass 的实例,但默认行为似乎是返回关联数组。框架只是在某些时候覆盖了它,导致 Capsule 以正确但意想不到的方式运行。这会将其设置为以更预期的行为运行。

关于php - 如何在 PHP 5.3.x 的其他框架中使用 Illuminate Database Query Builder 和 Eloquent,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20650031/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com