php - mySQL - 使用 JOIN 或嵌套 SELECT(子选择)进行选择?

标签 php mysql select left-join nested-select

我正在尝试在 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/

相关文章:

php - 在 php 上向收件人数组发送电子邮件

mysql - SQLworkbench中有关LIKE子句和Select语句的查询

php - 巨大的帖子状态表,从前 100 名中随机选择

mysql - 如何从多个表中选择同一列

php - 如何为mvc crud网站创建动态更新功能

php - AWS上执行 "PutObject"出错,上传失败

mysql - 搜索在 mysql 中一次更改多个表的简单方法

MySQL 表索引基数

php - 有没有办法在另一个wordpress页面中调用wordpress中的外部php页面

php - 如何使用 PHP 编写动态查询