3

如何在视图中访问 zend 数据库连接。

在我的情况下,我的用户 index.phtml 显示所有用户的列表,用户注册了多种语言,这些语言以 JSON 格式存储在数据库中

这是 indexAction。

return new ViewModel(array(
        'users'             => $this->getRegisterTable()->fetchAll(),
    ));

在 index.phtml 里面

<?php foreach ($users as $users):?>
<?php 
$getQuery = mysql_query("SELECT * FROM lang where id= $users->lang ");
$getResult = mysql_fetch_array($getQuery);
$lang = "<a href='" . $this->url(lang , array('action'=>'detail', 'id'=> $users->lang )) . "'>" .$getResult['name']."</a>";
 ?>
<?php endforeach;?>

因此,要执行此查询,我必须使用 MYSQL_CONNECT 手动初始化数据库连接

但我希望它只访问 zend 初始化数据库连接。

4

1 回答 1

1

正如其他人正确指出的那样,这是一件非常糟糕的事情。这些数据应该从你的控制器发送到视图,并且你的视图不应该使用数据库,甚至不知道正在使用数据库。通过打破 MVC(模型视图控制器)设计模式,您的代码将更难维护和理解。

如果我理解您想要正确执行的操作,那么您希望显示用户已注册的语言。我会在获取用户时获取此信息,以便您的User模型上可以使用这些语言。如果您使用 Mapper 类从中获取用户,那么您将在此处获取语言。然后在您看来,您应该这样做:

<?php foreach ($users as $user) : ?>
    <?php foreach ($user->getLanguages() as $language) : ?>
        <?php $lang = "<a href='" . $this->url('lang' , array('action'=>'detail', 'id'=> $language['id'] )) . "'>" . $language['name'] . "</a>"; ?>
    <?php endforeach; ?>
<?php endforeach; ?>

现在,您的表示(视图)层中不再有业务逻辑或数据访问逻辑。请记住使用escape视图助手从数据库中转义数据,如下所示:

<?php echo $this->escape($language['name']); ?>

我希望它有所帮助。一旦您启动并运行从单独层获取数据的架构,您将开始理解为什么这是最佳实践。

于 2013-04-21T14:26:25.663 回答