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')

转载于:https://www.cnblogs.com/yimengtianya1/p/8947798.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值