CakePHP查找相关数据

时间:2012-01-11 08:15:47

标签: cakephp cakephp-2.0 cakephp-appmodel

我的图库模型与我的图像模型有关,但是当我从galleries_controller中检索图像时,我看不到任何结果,而是看到此错误:

警告(2):为foreach()提供的参数无效[APP \ views \ galleries \ view.ctp,第35行]

以下是我的控制器操作的代码:

    function view($id = null) {
            if (!$id) {
                $this->Session->setFlash(__('Invalid gallery', true));
                $this->redirect(array('action' => 'index'));
            }
            $this->set('gallery', $this->Gallery->read(null,$id));
 $this->Gallery->Image->find('all',array('conditions' => array('Image.gallery_id'=> $id)));
             $this->set('images', $images);

        }

这是我在我的画廊/视图中循环遍历数组的循环。

<?php

        $i = 0;
        foreach ($images['Image'] as $image):
            $class = null;
            if ($i++ % 2 == 0) {
                $class = ' class="altrow"';
            }
        ?>
        <tr<?php echo $class;?>>
            <td><?php $image['id'] ;?></td>
            <td><?php echo $image['name'];?></td>
            <!--<td><?php echo $image['img_file'];?></td>-->

            <td><?php  echo $html->image('uploads' . DS . 'images' . DS . $image['img_file'], array('alt' => 'Gallery Image')); ?></td>

        </tr>
    <?php endforeach; ?>

1 个答案:

答案 0 :(得分:2)

您没有使用您的设置进行任何设置。您的查找正在执行,然后不会存储在变量中。此外,您的视图循环错误地迭代。

将您的控制器更改为:

  function view($id = null) {
            if (!$id) {
                $this->Session->setFlash(__('Invalid gallery', true));
                $this->redirect(array('action' => 'index'));
            }
            $this->set('gallery', $this->Gallery->read(null,$id));
 $images = $this->Gallery->Image->find('all',array('conditions' => array('Image.gallery_id'=> $id)));
             $this->set('images', $images);
        }

您的观看代码为:

<?php

        $i = 0;
        foreach ($images as $image):
            $class = null;
            if ($i++ % 2 == 0) {
                $class = ' class="altrow"';
            }
        ?>
        <tr<?php echo $class;?>>
            <td><?php $image['Image']['id'] ;?></td>
            <td><?php echo $image['Image']['name'];?></td>
            <!--<td><?php echo $image['Image']['img_file'];?></td>-->

            <td><?php  echo $html->image('uploads' . DS . 'images' . DS . $image['Image']['img_file'], array('alt' => 'Gallery Image')); ?></td>

        </tr>
    <?php endforeach; ?>

有人说过,因为您要做的就是在查看图库时拉入相关图像,您应该考虑设置模型关联,然后在您的图库中进行查找,其中包含您想要的图像这样:

$this->set('gallery',$this->Gallery->find('first', array('conditions' => array('Gallery.id' => $id), 'recursive' => 1));

如果上述方法不起作用,那么您的模型中会出现配置错误。请发布您的型号代码,以便我们进一步调查。