我正在尝试建立一个涉及两个表“新闻和页面”的搜索系统。
我的新闻表:
我的页面表格
当用户写一个单词并提交表单时,我将选择搜索该单词,其中我的表格新闻和页面的标题和内容与该单词相似。
所以我想选择我的两个表来访问这两个表的字段,因为我想在列表中显示查询结果。
我正在使用这个sql语句:
SELECT id_news, thumb, title, content, date, statuss, category FROM news
WHERE statuss = '%e%' AND title LIKE '%e%' OR content LIKE '%e%'
UNION
SELECT id_pag, title_pag, content_pag, link, NULL, NULL, NULL FROM pages
WHERE title_pag LIKE '%e%' OR content_pag LIKE '%e%' LIMIT 0,10
我得到了这个:
所以问题是:我想在列表中显示结果,并且我不想只访问我的新闻字段,我还想访问我的表格页面列。
但我只是可以访问我的新闻表列,当我这样做时:
if($result['id_pag'] != ''){
echo '<a href="'.BASE.$result['link'].'">'.$result['title_pag'].'</a>';
}
我收到此通知:通知:未定义索引:id_pag
这是我的代码:
echo '<ul class="searchlist">';
$read = $pdo->prepare("SELECT id_news, thumb, title, content, date, statuss, category FROM news
WHERE statuss = ? AND title LIKE ? OR content LIKE ?
UNION
SELECT id_pag, title_pag, content_pag, link, NULL, NULL, NULL FROM pages
WHERE title_pag LIKE ? OR content_pag LIKE ? LIMIT 0,10 ");
$read->bindValue(1, '1');
$read->bindValue(2, "%search%", PDO::PARAM_STR);
$read->bindValue(3, "%$search%", PDO::PARAM_STR);
$read->bindValue(4, "%$search%", PDO::PARAM_STR);
$read->bindValue(5, "%$search%", PDO::PARAM_STR);
$read->execute();
while ($result = $read->fetch(PDO::FETCH_ASSOC)){
echo '<li>';
if($result['id_news'] != ''){
echo '<a href="#">';
echo '<img src="'.BASE.'/uploads/news/'.$result['thumb'].'"/>';
echo '</a>';
}
if($result['id_pag'] != ''){
echo '<a href="'.BASE.$result['link'].'">'.$result['title_pag'].'</a>';
}
echo '</li>';
}
echo ' </ul>';
你能帮我一个忙吗?
最佳答案
使用UNION
时,将从第一个SELECT
开始使用列名称,其他名称将丢失。
如果您需要区分这两个集合,您可以向查询添加一个 type
列,如下所示:
SELECT 'news' `type`, id_news, thumb, title, content, date, statuss, category
FROM news
WHERE statuss = '%e%' AND title LIKE '%e%' OR content LIKE '%e%'
UNION
SELECT 'pages', id_pag, title_pag, content_pag, link, NULL, NULL, NULL
FROM pages
WHERE title_pag LIKE '%e%' OR content_pag LIKE '%e%' LIMIT 0,10
然后您可以使用 $result['type']
作为 if
条件。
但是,您的两个结果集差异很大,因此我只运行两个查询。它看起来 super 老套。
关于php - 注意undefined_index,使用带有两个表的select来访问两个表的字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24762687/