2017-04-07 65 views
2

我正在尝试使用zend表现力,看着如何做数据库的东西。我在看this,但目前还不清楚。我使用composer来安装zend-db,它提到在dependencies.global.php中添加一行,然后在工厂类中使用容器来获取适配器,但之后没有讨论如何在实际操作类中访问它由于适配器对象超出了其他类的范围,我不知道发生了什么。zend expressive - zend db

任何人都有从开始到结束的良好和明确的例子,实际上能够连接和查询SQL?

+0

你有没有得到任何例子来整合Zend/D b最后有表现力吗?这可能会有所帮助,因为我也在为同一主题奋斗。 – Leo

回答

0

尝试通过厂注入你的DB类,遵循例如在骨架的应用程序,你可以做这样的事情:

HomePageFactory.php 

    public function __invoke(ContainerInterface $container) 
{ 
    $router = $container->get(RouterInterface::class); 
    $template = $container->has(TemplateRendererInterface::class) ? $container->get(TemplateRendererInterface::class) : null; 

    $adapter = $container->get(Adapter::class); 
    $usersTable = $container->get(Table\UsersTable::class); 


    return new HomePageAction($router, $template,$adapter,$usersTable); 
} 

HomePageAction.php

class HomePageAction implements ServerMiddlewareInterface 
{ 
/** 
* @var Router\RouterInterface 
*/ 
private $router; 

/** 
* @var null|Template\TemplateRendererInterface 
*/ 
private $template; 

/** 
* @var Adapter 
*/ 
private $dbAdapter; 

/** 
* @var UsersTable 
*/ 
private $usersTable; 

/** 
* HomePageAction constructor. 
* @param Router\RouterInterface $router 
* @param Template\TemplateRendererInterface|null $template 
* @param Adapter $adapter 
* @param UsersTable $usersTable 
*/ 
public function __construct(Router\RouterInterface $router, Template\TemplateRendererInterface $template = null, Adapter $adapter, Table\UsersTable $usersTable) 
{ 
    $this->router  = $router; 
    $this->template = $template; 
    $this->dbAdapter = $adapter; 
    $this->usersTable = $usersTable; 

} 

上,你有你的配置提供商你的桌子必须配置依赖作为工厂EX:

'factories' => [ 

      Table\UsersTable::class => function($container) { 
       $dbAdapter   = $container->get(AdapterInterface::class); 
       $resultSetPrototype = new ResultSet(); 
       $resultSetPrototype->setArrayObjectPrototype(new Model\Users()); 
       $tableGateway  = new TableGateway('users', $dbAdapter, null, $resultSetPrototype); 
       return new Table\UsersTable($tableGateway); 
      }, 

     ], 
+0

在这个实现中,UserTable.php必须在App/src/models /上创建才能被提供,对吗? – Leo

+1

你想在哪里:),但是。 – rafaelphp

+0

您能否请您更新您的答案并给出该UsersTable类和用户模型的示例?以及如何处理简单的查询?我已经失去了我试过多少attemps使框架工作 – Leo