13子查询
1.使用IN关键字的子查询
问题:查询游戏类型是“棋牌类”的游戏的分数信息
游戏分数表中并未包含游戏类型信息
思路一:采用连接查询
思路二:分两步进行,首先找到所有“棋牌类”游戏的编号,在以这一组编号为查询依据完成查询
思路二示例1:
SELECT * FROM scores
where gno IN #查询依据
(SELECT gno from games WHERE gtype = "棋牌 ") #查询子句
注:子查询一般不写成SELECT * FROM...
思路二示例2:查询没有参与5号游戏的玩家QQ
SELECT user_qq FROM scores
where user_qq NOT IN
(SELECT user_qq from scores WHERE GNO = 5)
以上写法错误:分数表中并没有包含所有玩家的QQ,而只包含了玩了游戏的玩家。没有参与游戏的玩家自然不在scores表中。
以下
SELECT user_qq FROM users
LEFT JOIN scores ON users.user_qq = scores.user_qq
where user_qq NOT IN
(SELECT user_qq from users WHERE GNO = 5)
思路二示例3:查询没有参与5号游戏的玩家QQ、玩家GNO
SELECT users.user_qq ,GNO FROM users
LEFT JOIN scores ON users.user_qq = scores.user_qq
where users.user_qq NOT IN
(SELECT scores.user_qq from scores WHERE GNO = 5)
注:当users表内不存在GNO的字段时,需要外连接scores表的字段GNO。
2.使用EXISTS关键字的子查询
示例:如果存在昵称为“dang”,则查询分数表中的数据。
SELECT * FROM scores
WHERE EXISTS
(SELECT * FROM users WHERE user_name = 'dang')