我将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" }
出于某种原因,这不会返回多个问题,尽管搜索应该有更多。
答案 0 :(得分:1)
你不需要使用另一个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')
,这样就不必在上面的循环中将if放在foreach中。