我正在尝试在 mySQL(和 PHP)中编写一个 SELECT,它将检索“图像”表中尚未被特定用户排名的所有行。
那些是我的表:
表格:图片
+-----------+----------+-----------+----------+
| Index | Rank_Good| Rank_OK | Rank_Bad |
+-----------+----------+-----------+-----------
| 201 | 2 | 9 | 28 |
| 202 | 11 | 20 | 39 |
| 203 | 36 | 14 | 7 |
+-----------+----------+-----------+----------+
表 2:WhoAlreadyClickedImg(没有索引)
+------------+-----------------+-----------+
| ImageIndex | UserWhoRankedIt | RankGiven |
+------------+-----------------+-----------+
| 202 | 87 | OK |
+------------+-----------------+-----------+
| 202 | 93 | Bad |
+------------+-----------------+-----------+
| 204 | 93 | Good |
+------------+-----------------+-----------+
| 203 | 94 | Bad |
+------------+-----------------+-----------+
每次用户对图像进行排名时,“图像”表都会更新,并向“WhoAlreadyClickedImg”表中添加一行。 (此表无索引)
例如,如果用户对图像索引 202 的排名为“ok”,则列“Rank_OK”将更新为 (+1),然后,新行将添加到“WhoAlreadyClickedImg”表中:
图片索引:201 | UserWhoRankedIt:(使用的 session ID) | RankGiven:好的
我想构建一个不会向已经对它进行排名的用户显示相同图像两次的选择。
例如,如果我是用户“93”,则选择将带来的唯一图像是“203”
更新:
这是我正在使用的查询(@eamonn):
SELECT * FROM Images WHERE Index NOT IN (SELECT ImageIndex FROM WhoAlreadyClickedImg WHERE UserWhoRankedIt = 93);
但是我得到一个错误:
您的 SQL 语法有误;查看与您的 MySQL 服务器版本对应的手册,了解在第 1 行的“Index NOT IN (SELECT ImageIndex FROM WhoAlreadyClickedImg WHERE UserWhoRankedIt'”附近使用的正确语法
我检查了我的系统:
存储引擎:InnoDB
MySQL数据库版本:5.5.33-29.3
两个表现在都有 Index,int(11),定义为 PRIMARY,auto_increment
也许有人有想法?
最佳答案
在那里,这应该可以工作:
SELECT Images.Index
FROM Images
WHERE Images.Index NOT IN
(
SELECT WhoAlreadyClickedImg.ImageIndex
FROM WhoAlreadyClickedImg
WHERE WhoAlreadyClickedImg.UserWhoRankedIt = 93
);
请记住在列名之前添加表的名称。
关于php - mySQL - 使用 JOIN 或嵌套 SELECT(子选择)进行选择?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44283361/