首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有Doctrine和PHP类的Silex

带有Doctrine和PHP类的Silex
EN

Stack Overflow用户
提问于 2017-03-31 07:40:24
回答 2查看 217关注 0票数 1

所以,我想在西里克斯到处走走。只要学习一下它的工作原理,我就会尝试在其中使用原理。我可以在index.php上使用它,但我也想在我的类中使用它。这些行在普通根文件(index.php)中使用:

代码语言:javascript
复制
$images = $app['db']->prepare("SELECT * FROM images");
$images->execute();

$images = $images->fetchAll(\PDO::FETCH_CLASS, \AI\Models\Image::class);

这样我就可以对图像做些什么了。但我不想这样工作。我希望课堂能为我做所有的事情,所以我只编写了一些方法,为我做所有的艰苦工作。这样我就可以在index.php的每条线路上运行一行

问题是,我不知道如何从我的类内连接原则。因为里面没有“$app”。我认为在类内启动应用程序是很奇怪的。

假设我想创建一个用户类。这个SQL将给我所有的用户:"SELECT * FROM user“。但是如何在用户类中使用Doctrine呢?

代码语言:javascript
复制
<?php

namespace Models;

class User {

    public function find($user){
        if($user) {
            $field = (is_numeric($user)) ? 'id' : 'username';

            $sql = "SELECT * FROM users";

            $data = // RUN QUERY $SQL 
            if($data->count()) {
                $this->_data = $data->all();
                return true;
            }
        }
        return false;
    }

}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-03-31 15:49:05

在您的index.php中,请遵循以下步骤。

  • 创建silex应用程序的实例: $app = new \Application();$app->$app(新的$app)
  • 设置数据库配置: $config = new \Doctrine\DBAL\配置( );$connParams =数组(‘=>’驱动程序‘、'dbname’=> 'dbname‘、’主机‘=>’主机‘、’用户‘=>’用户‘、’密码‘=> 'pass’、'charset‘=> 'charset’、‘端口’=>‘端口’);
  • 连接到数据库: ( \Doctrine\DBAL\DriverManager::getConnection($connParams,$config);

现在,您有了不同的方法可以在整个应用程序中访问这个db实例。您是否可以创建一个全局变量,在其中添加实例:

代码语言:javascript
复制
global $dbcon;
$dbcon = $conn;

或者简单地将其添加到$app本身:

代码语言:javascript
复制
$app['dbcon'] = $conn;

此外,您可能希望向模型中添加一个构造函数,如下所示:

代码语言:javascript
复制
public function __construct($db)
{
    $this->db = $db;
}
票数 0
EN

Stack Overflow用户

发布于 2017-03-31 07:47:17

您需要在控制器中注入这些实例。我很快就翻阅了一下文档,认为我找到了你需要的东西。

这里有一个指向文档页面的链接:controller.html

文档页解释了您需要知道的一切,以获得您想要实现的目标。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43135192

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档