我正在尝试一个涉及两个表“News& Pages”的搜索系统。
我的新闻表:
我的网页表
当用户写一个单词并提交表格时,我会做一个选择来搜索那个单词的标题和我的表格新闻和页面的内容就像那个单词一样。
所以我想选择我的两个表来访问那两个表的字段,因为我想在列表中显示查询结果。
我正在使用这个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>';
你能帮我一个忙吗?
答案 0 :(得分:2)
使用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
条件。
但是,您的两个结果集非常不同,我只会运行两个查询。它看起来非常黑客。