我正在将SQL查询结果存储在一个$data
变量中,并将其从我的模型中传递给如下所示的search_view
:
$this->db->like('LOWER(title)', strtolower($query));
$q = $this->db->get('questions');
$data = $q->row_array();
$this->load->view('search_view', array('data' => $data));
我正在尝试使用以下结构在我的视图中显示所有结果:
<?php if ($data['search_type'] == 'question') {
foreach ($data as $question) {
?>
<div class="question-result">
<h2><?php echo $question['title']; ?></h2>
<p>Posted by: <a href="#"><?php echo $question['username']; ?>username</a></p>
<p>Date Posted: <?php echo $question['date']; ?></p>
</div>
<?php } } ?>
我需要检查$data['search_type']以查看执行了哪种类型的搜索,此位经过测试并且可以正常工作,但是无需担心
对于我使用的所有变量(如用户名、标题和日期),我收到非法的字符串偏移错误。
EDDIT* 示例转储:
array(7) { ["question_id"]=> string(1) "3" ["title"]=> string(19) "First Question Ever" ["content"]=> string(13) "Hello Content" ["date"]=> string(19) "2015-01-03 15:08:30" ["user_id"]=> string(2) "14" ["username"]=> string(4) "Ilya" ["search_type"]=> string(8) "question" }
出于某种原因,这不会返回多个问题,尽管执行的搜索应该有更多问题。
你不需要使用另一个foreach,因为它不再在另一个维度上。使用->row_array()
仅返回一行。
<?php if ($data['search_type'] == 'question') { ?>
<div class="question-result">
<h2><?php echo $data['title']; ?></h2>
<p>Posted by: <a href="#"><?php echo $data['username']; ?>username</a></p>
<p>Date Posted: <?php echo $data['date']; ?></p>
</div>
<?php } ?>
如果您希望获得更多结果,请改用->result_array()
:
$data = $q->result_array();
然后查看:
<?php foreach ($data as $question): ?>
<?php if ($question['search_type'] == 'question') { ?>
<div class="question-result">
<h2><?php echo $question['title']; ?></h2>
<p>Posted by: <a href="#"><?php echo $question['username']; ?>username</a></p>
<p>Date Posted: <?php echo $question['date']; ?></p>
</div>
<?php endif; ?>
<?php endforeach; ?>
或者也可以只添加$this->db->where('search_type', 'question')
这样你就不必在上面的循环中在foreach内放置一个if。