0

使用 UNION ALL 时,我在将 sql 查询的结果作为链接回显时遇到问题。

表格如下所示:

表:帖子
id 用户名 日期 评论

表:文件
id 用户名日期文件

“文件”行包含上传文件的 url。

我用于显示结果的代码:

<?php
$sql="SELECT * FROM posts 
UNION ALL 
SELECT * FROM files 
ORDER BY date DESC LIMIT 100";
$result=mysql_query($sql);
while($rows=mysql_fetch_array($result)){
?>

<div> <?php echo $rows['comment']; ?> </div>
<div> <a href="<?php echo $rows['file']; ?>"><?php echo $rows['file']; ?></a> </div>

<?php
}
?>

现在一切都按正确的顺序排列,但文件名不会显示为链接,只有纯文本。没有问题,如果我只在文件表上运行查询,则回显链接。

我想最大的问题是:如何将 UNION ALL 查询的结果显示为链接?

4

2 回答 2

2

当您执行 UNION 查询时,列被组合,这意味着您的列commentfile列将是相同的,其结果集名称将是comment(第一个 select 语句)。见http://dev.mysql.com/doc/refman/5.0/en/union.html

我更倾向于使用两个单独的查询,一个针对poststable,第二个针对files.

于 2012-03-26T01:20:10.390 回答
0

如果您在帖子表中有

1  2012-03-26 "a comment"
2  2012-03-26 "another comment"

在文件表中:

1  2012-03-26 "./myfile/txt"
2  2012-03-26 "./ico.gif"

工会将是:

ID Date       Comment/file
1  2012-03-26 "a comment"
1  2012-03-26 "./myfile/txt"
2  2012-03-26 "another comment"
2  2012-03-26 "./ico.gif"

(不保证订单)

因此,如果您尝试为每一行打印一个带有注释的 div 和一个带有文件作为链接的 div,这将不起作用。在您的情况下,它似乎只显示评论 div(因为查询结果行名必须是评论)

但是,如果您想要实现的目标可以使用上述连接来完成。可能是这样,如果帖子 id 与具有相同 id 的文件行匹配

SELECT p.comment comment f.file file FROM posts p
INNER JOIN files f ON f.id = p.id

结果将是:

 comment          file
"a comment"       "./myfile/txt"
"another comment" "ico.gif"

问候

于 2012-03-26T01:19:11.720 回答