• 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')
  • 相关阅读:
    使用js获取表单元素的值
    分页问题
    空值转换问题
    MySQL数据库操作基础
    二叉树DFS遍历递归和非递归做法
    BFS经典算法
    stack & queue及经典例题
    Recursion & Binary search
    Leetcode之SpiralMatrix(I,II)
    Leetcode之贪心算法
  • 原文地址:https://www.cnblogs.com/yimengtianya1/p/8947798.html
Copyright © 2020-2023  润新知