mySQL - SELECT 使用 JOIN,还是嵌套的 SELECT (sub-select)?
mySQL - SELECT using JOIN, or a nested SELECT (sub-select)?
我正在尝试在 mySQL(和 PHP)中编写一个 SELECT,它将检索 "Images" table 中没有的所有行某个用户尚未排名。
这些是我的 tables:
Table:图片
+-----------+----------+-----------+----------+
| Index | Rank_Good| Rank_OK | Rank_Bad |
+-----------+----------+-----------+-----------
| 201 | 2 | 9 | 28 |
| 202 | 11 | 20 | 39 |
| 203 | 36 | 14 | 7 |
+-----------+----------+-----------+----------+
Table2: WhoAlreadyClickedImg(没有索引)
+------------+-----------------+-----------+
| ImageIndex | UserWhoRankedIt | RankGiven |
+------------+-----------------+-----------+
| 202 | 87 | OK |
+------------+-----------------+-----------+
| 202 | 93 | Bad |
+------------+-----------------+-----------+
| 204 | 93 | Good |
+------------+-----------------+-----------+
| 203 | 94 | Bad |
+------------+-----------------+-----------+
每次用户对图像进行排名时,table "Images" 都会更新,并且会在 "WhoAlreadyClickedImg" table 中添加一行。 (这个table没有索引)
例如,如果用户用 "ok" 排名图像索引 202,则列 "Rank_OK" 将更新为 (+1),然后,新行将添加到 "WhoAlreadyClickedImg" table:
图片索引:201 | UserWhoRankedIt:(使用的会话 ID) | RankGiven:好的
我想构建一个 select 不会向已经对它进行排名的用户显示两次相同的图像。
例如,如果我是用户“93”,select 将带来的唯一图像是“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
两个 table 现在都有索引,int(11),定义为 PRIMARY,auto_increment
也许有人有想法?
SELECT * FROM Images WHERE Index NOT IN
(SELECT ImageIndex FROM WhoAlreadyClickedImg WHERE UserWhoRankedIt = 93);
简单的子查询。
列名 Index 是 MySQL 中的保留关键字。您应该将索引列的名称更改为 Id 或 MainIndex。看到这个 link:https://dev.mysql.com/doc/refman/5.6/en/keywords.html
另一种选择是在 select 查询中使用 table 名称。例如:
SELECT * FROM Images WHERE Images.Index NOT IN (SELECT ImageIndex FROM WhoAlreadyClickedImg WHERE UserWhoRankedIt = 93);
我认为您应该重命名您的专栏,因为这样可以最大限度地减少 SQL 语句中出错的可能性。
在那里,这应该有效:
SELECT Images.Index
FROM Images
WHERE Images.Index NOT IN
(
SELECT WhoAlreadyClickedImg.ImageIndex
FROM WhoAlreadyClickedImg
WHERE WhoAlreadyClickedImg.UserWhoRankedIt = 93
);
记得在列名前添加表名。
我正在尝试在 mySQL(和 PHP)中编写一个 SELECT,它将检索 "Images" table 中没有的所有行某个用户尚未排名。
这些是我的 tables:
Table:图片
+-----------+----------+-----------+----------+
| Index | Rank_Good| Rank_OK | Rank_Bad |
+-----------+----------+-----------+-----------
| 201 | 2 | 9 | 28 |
| 202 | 11 | 20 | 39 |
| 203 | 36 | 14 | 7 |
+-----------+----------+-----------+----------+
Table2: WhoAlreadyClickedImg(没有索引)
+------------+-----------------+-----------+
| ImageIndex | UserWhoRankedIt | RankGiven |
+------------+-----------------+-----------+
| 202 | 87 | OK |
+------------+-----------------+-----------+
| 202 | 93 | Bad |
+------------+-----------------+-----------+
| 204 | 93 | Good |
+------------+-----------------+-----------+
| 203 | 94 | Bad |
+------------+-----------------+-----------+
每次用户对图像进行排名时,table "Images" 都会更新,并且会在 "WhoAlreadyClickedImg" table 中添加一行。 (这个table没有索引)
例如,如果用户用 "ok" 排名图像索引 202,则列 "Rank_OK" 将更新为 (+1),然后,新行将添加到 "WhoAlreadyClickedImg" table:
图片索引:201 | UserWhoRankedIt:(使用的会话 ID) | RankGiven:好的
我想构建一个 select 不会向已经对它进行排名的用户显示两次相同的图像。
例如,如果我是用户“93”,select 将带来的唯一图像是“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
两个 table 现在都有索引,int(11),定义为 PRIMARY,auto_increment
也许有人有想法?
SELECT * FROM Images WHERE Index NOT IN
(SELECT ImageIndex FROM WhoAlreadyClickedImg WHERE UserWhoRankedIt = 93);
简单的子查询。
列名 Index 是 MySQL 中的保留关键字。您应该将索引列的名称更改为 Id 或 MainIndex。看到这个 link:https://dev.mysql.com/doc/refman/5.6/en/keywords.html
另一种选择是在 select 查询中使用 table 名称。例如:
SELECT * FROM Images WHERE Images.Index NOT IN (SELECT ImageIndex FROM WhoAlreadyClickedImg WHERE UserWhoRankedIt = 93);
我认为您应该重命名您的专栏,因为这样可以最大限度地减少 SQL 语句中出错的可能性。
在那里,这应该有效:
SELECT Images.Index
FROM Images
WHERE Images.Index NOT IN
(
SELECT WhoAlreadyClickedImg.ImageIndex
FROM WhoAlreadyClickedImg
WHERE WhoAlreadyClickedImg.UserWhoRankedIt = 93
);
记得在列名前添加表名。