[英]mySQL - SELECT using JOIN, or a nested SELECT (sub-select)?
我正在嘗試在mySQL(和PHP)中編寫SELECT,它將檢索“ Images”表中尚未由特定用戶排名的所有行。
這些是我的表:
表: 圖像
+-----------+----------+-----------+----------+
| 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 |
+------------+-----------------+-----------+
每次用戶對圖像進行排名時,表“ Images”都會更新,並將行添加到“ WhoAlreadyClickedImg”表中。 (該表沒有索引)
例如,如果用戶使用“ ok”對圖像索引202進行排名,則col“ Rank_OK”將更新為(+1),然后將新行添加到“ WhoAlreadyClickedImg”表中:
圖片索引:201 | UserWhoRankedIt :(使用的會話ID) | RankGiven:好的
我想建立一個選擇,它將不會對已經對其進行排名的用戶顯示兩次相同的圖像。
例如,如果我的用戶是“ 93”,則選擇將帶來的唯一圖像是“ 203”
更新:
這是我正在使用的查詢(@eamonn提供):
SELECT * FROM不在索引中的圖像(SELECT ImageIndex從WhoAlreadyClickedImg WHERE UserWhoRankedIt = 93);
但我得到一個錯誤:
您的SQL語法有誤; 檢查與您的MySQL服務器版本相對應的手冊以獲取正確的語法,以在第1行的“索引不輸入(從WhoAlreadyClickedImg WHERE UserWhoRankedIt選擇SELECT ImageIndex)附近使用
存儲引擎:InnoDB
MySQL db版本:5.5.33-29.3
這兩個表現在都有索引int(11),定義為PRIMARY,auto_increment
也許有人有主意?
SELECT * FROM Images WHERE Index NOT IN (SELECT ImageIndex FROM WhoAlreadyClickedImg WHERE UserWhoRankedIt = 93);
簡單的子查詢。
好吧,列名Index是MySQL中的保留關鍵字。 您應該將索引列的名稱更改為Id或MainIndex。 看到這個鏈接: https : //dev.mysql.com/doc/refman/5.6/en/keywords.html
另一種選擇是在選擇查詢中使用表名。 例如:
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
);
切記在表名之前添加表名。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.