zoukankan      html  css  js  c++  java
  • 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')
  • 相关阅读:
    宁波工程学院2020新生校赛C
    宁波工程学院2020新生校赛B
    宁波工程学院2020新生校赛A -恭喜小梁成为了宝可梦训练家~(水题)
    POJ 1611
    牛客算法周周练11E
    牛客算法周周练11C
    牛客算法周周练11A
    CodeForces 1176C
    CodeForces 445B
    UVALive 3027
  • 原文地址:https://www.cnblogs.com/yimengtianya1/p/8947798.html
Copyright © 2011-2022 走看看