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')
  • 相关阅读:
    重写/覆盖基类的事件
    关于“日志”的输出控制
    WPF中DataGrid垂直滚动条滚动后导致每行CheckBox选择错乱
    WPF窗体应用程序开发
    C# 操作自定义config文件
    WPF绑定数据源之RelativeSource
    C# http请求 设置代理(标题可以作为搜索关键字)
    前端加载特效
    实现不同的项目,用不同的git 账号提交
    Casbin 使用记录
  • 原文地址:https://www.cnblogs.com/yimengtianya1/p/8947798.html
Copyright © 2011-2022 走看看