gpt4 book ai didi

php - 尝试加入空表没有返回

转载 作者:行者123 更新时间:2023-11-29 07:48:53 24 4
gpt4 key购买 nike

我在尝试将空表(评论表)加入到我现有的准备好的语句中时遇到问题。

这工作完美:

// prepare images
if ($stmt = $mysqli->prepare(" SELECT uu.*, m.*,
(
SELECT COUNT(*)
FROM img_likes AS t
WHERE t.img_id = uu.imgID AND t.user_id = ?
) AS user_likes,
(
SELECT COUNT(*)
FROM img_likes AS t
WHERE t.img_id = uu.imgID
) AS total_likes
FROM user_uploads AS uu
INNER JOIN members AS m ON m.id = uu.user_id
ORDER BY up_time DESC")) {
$stmt->bind_param('i', $user_id);
$stmt->execute(); // get imgs

// foreach print images
// working as expected
}

而且我不知道为什么如果我加入另一个空表(img_comments),则不会打印图像...如果我向表中添加一行并刷新页面,则会打印一个图像...

我正在尝试但不起作用的声明是这样的:

SELECT uu.*, m.*, ic.*,
(
SELECT COUNT(*)
FROM img_likes AS t
WHERE t.img_id = uu.imgID AND t.user_id = ?
) AS user_likes,
(
SELECT COUNT(*)
FROM img_likes AS t
WHERE t.img_id = uu.imgID
) AS total_likes
FROM user_uploads AS uu
INNER JOIN members AS m ON m.id = uu.user_id
INNER JOIN img_comments AS ic ON ic.img_id = uu.imgID
ORDER BY up_time DESC

为什么只根据表格行数打印图像?我也尝试过 LEFT JOIN 但我对此不太熟悉。我只在其他脚本中使用 INNER JOIN,从来没有遇到过这样的问题。

如果对我的查询有任何优化,我将不胜感激。

最佳答案

内连接有什么作用?它将表 a 的所有记录与表 b 的所有匹配记录连接起来。因此,当b表中没有记录时,a表中的任何记录都没有匹配,因此根本没有结果。为什么这会让您感到惊讶?

左连接是外连接(LEFT OUTER JOIN 的缩写)。意思是:给我a表的所有记录和b表所有匹配的记录,当没有匹配时无论如何给我a表的记录。这似乎就是你想要的。但你说你试过了。我不明白这会在您的查询中失败。

外连接不起作用的一个典型错误是在 where 子句中包含 b 的某些字段(例如,where b.id > 100)。由于外连接记录没有匹配的b记录,因此所有b字段都为空,因此这样的where子句将失败。您将再次获得匹配项,就像内部联接一样。

编辑:至于优化,您可以通过有条件计数一次获得两个计数:

SELECT 
uu.*, m.*, ic.*,
il.count_user AS user_likes,
il.count_total AS total_likes
FROM user_uploads AS uu
INNER JOIN members AS m ON m.id = uu.user_id
LEFT OUTER JOIN img_comments AS ic ON ic.img_id = uu.imgID
LEFT OUTER JOIN
(
select
img_id,
count(*) as count_total,
count(case when t.user_id = ? then 1 end) as count_user
from img_likes
group by img_id
) AS il ON il.img_id = uu.imgID
ORDER BY uu.up_time DESC;

关于php - 尝试加入空表没有返回,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26966524/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com