注意undefined_index,使用带有两个表的select来访问两个表的字段

时间:2014-07-15 15:50:56

标签: php mysql sql pdo

我正在尝试一个涉及两个表“News& Pages”的搜索系统。

我的新闻表:

enter image description here

我的网页表

enter image description here

当用户写一个单词并提交表格时,我会做一个选择来搜索那个单词的标题和我的表格新闻和页面的内容就像那个单词一样。

所以我想选择我的两个表来访问那两个表的字段,因为我想在列表中显示查询结果。

我正在使用这个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   

我得到了这个:

enter image description here

所以问题是:我想在列表中显示结果,我不想只访问我的新闻栏目,我也想访问我的表页列。

但是,当我这样做时,我只能访问我的新闻表专栏:

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>';
你能帮我一个忙吗?

1 个答案:

答案 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条件。

但是,您的两个结果集非常不同,我只会运行两个查询。它看起来非常黑客。