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

标签 php mysql sql pdo

我正在尝试建立一个涉及两个表“新闻和页面”的搜索系统。

我的新闻表:

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>';

你能帮我一个忙吗?

最佳答案

使用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/

相关文章:

php - 从 mysql 的单个字段访问逗号分隔符后的值(Codeigniter)

php - 从for循环向数据库插入错误

mysql - Ruby MySQL 数据库迁移脚本

mysql - 动态更新表并重新排列记录

mysql - UPDATE 的目标表不可更新

php检查数组的数组中是否存在值

javascript - 多个链式 SELECT 标签 JavaScript 和 jQuery

java - 如何使用 JPA 设置 MySQL AUTO_INCREMENT

sql - 在 SQL 中,如何获取表中列值最低的所有行?

php - 如何获取具有给定日期值的 varchar 日期列