• SQL Server教程 - T-SQL-DQL(Data Query Language)


    更新记录
    转载请注明出处:https://www.cnblogs.com/cqpanda/p/16527471.html
    2022年7月30日 发布。
    2022年7月2日 从笔记迁移到博客。

    T-SQL-DQL(Data Query Language)

    简单形式

    查询单列

    1. SELECT [列名]
    2. FROM [表名];

    查询多列

    1. SELECT [列名],[列名],[列名]
    2. FROM [表名];

    查询所有列

    1. SELECT *
    2. FROM [表名];

    去除重复

    1. SELECT ALL | DISTINCT [列名]
    2. FROM [表名];

    设置表和列别名

    1. SELECT [列] AS [别名]
    2. FROM [表名] AS [别名];

    限制查询条数

    1. SELECT TOP 数量 [PERCENT] 列名...
    2. FROM [表];

    条件筛选

    1. SELECT [列名]
    2. FROM [表名]
    3. WHERE <条件>;

    插入到新表

    说明:使用INTO子句
    注意:INTO语句会创建新表,旧表会导致报错

    1. SELECT [列名], [列名]
    2. INTO [表名]
    3. FROM [表名];

    实例:插入到临时表

    1. SELECT * INTO #TempPanda
    2. FROM [表名];

    排序

    ORDER BY 用于对结果集进行排序。
    ASC :升序(默认)
    DESC :降序
    可以按多个列进行排序,并且为每个列指定不同的排序方式

    1. SELECT
    2. FROM [表名]
    3. WHERE 条件
    4. ORDER BY 列 [ASC | DESC];

    排序时NULL 值如何处理
    在处理查询结果中没有重复值时,如果指定的列中有多个NULL值,则作为相同的值对待,显示结果中只有一个空值。对于使用 ORDER BY子句排序得到的结果集中,若存在NULL值,升序排序时有NULL值的记录将显示在最前面,而降序时NULL值将显示在最后面。

    实例:随机排序(使用GUID)

    order by newid()

    分组

    GROUP BY
    GROUP BY 子句将记录分组到汇总行中
    GROUP BY 为每个组返回一个记录
    GROUP BY 通常还涉及聚合:COUNT,MAX,SUM,AVG 等
    GROUP BY 可以按一列或多列进行分组
    GROUP BY 按分组字段进行排序后,ORDER BY 可以以汇总字段来进行排序

    HAVING
    HAVING 用于对汇总的 GROUP BY 结果进行过滤
    HAVING 要求存在一个 GROUP BY 子句
    WHERE 和 HAVING 可以在相同的查询中
    HAVING vs WHERE
    WHERE 和 HAVING 都是用于过滤
    HAVING 适用于汇总的组记录;而 WHERE 适用于单个记录

    1. SELECT
    2. FROM [表名]
    3. WHERE 条件
    4. GROUP BY
    5. ORDER BY 列 [ASC | DESC];

    分页

    注意:SQL Server2012起可用

    1. SELECT *
    2. FROM [表名]
    3. ORDER BY [列名]
    4. OFFSET [跳过的行数] ROWS
    5. FETCH NEXT [获得的行数] ROWS ONLY;

    注意:跳过的行号为0则不跳过任何行

    模式匹配

    关键字

    1. LIKE
    2. NOT LIKE

    注意:

    • 只有字段是文本类型时才使用 LIKE。
    • LIKE 支持两个通配符匹配选项:% 和 _。
    • 不要滥用通配符,通配符位于开头处匹配会非常慢。
    • % 表示任何字符出现任意次数。
    • _ 表示任何字符出现一次。

    匹配符号

    1. % -- 0个或多个字符
    2. _ -- 1个字符
    3. [] -- 匹配[]内的任意字符
    4. [^] -- 匹配除了[]内的任意字符

    实例:

    1. _
    2. SELECTFROM
    3. WHERELIKE '_panda';
    4. %
    5. SELECTFROM
    6. WHERELIKE '%panda%';
    7. []
    8. SELECTFROM
    9. WHERELIKE '[pc]';
    10. [^]
    11. SELECTFROM
    12. WHERELIKE '[^pc]';

    其他实例:

    WHERE SALARY LIKE '_00%'

    Finds any values that have 00 in the second and third positions

    WHERE SALARY LIKE '2_%_%'

    Finds any values that start with 2 and are at least 3 characters in length

    WHERE SALARY LIKE '%2'

    Finds any values that end with 2

    WHERE SALARY LIKE '_2%3'

    Finds any values that have a 2 in the second position and end with a 3

    WHERE SALARY LIKE '2___3'

    Finds any values in a five-digit number that start with 2 and end with 3

    子查询

    子查询是嵌套在较大查询中的 SQL 查询
    子查询也称为内部查询或内部选择
    而包含子查询的语句也称为外部查询或外部选择
    子查询可以嵌套在 SELECT,INSERT,UPDATE 或 DELETE 语句内或另一个子查询中
    子查询通常会在另一个 SELECT 语句的 WHERE 子句中添加
    可以使用比较运算符,如 >,<,或 =
    比较运算符也可以是多行运算符,如 IN,ANY 或 ALL
    子查询必须被圆括号 () 括起来
    内部查询首先在其父查询之前执行,以便可以将内部查询的结果传递给外部查询

    子查询语法

    1. SELECT column_name [, column_name ]
    2. FROM table1 [, table2 ]
    3. WHERE column_name OPERATOR
    4. (SELECT column_name [, column_name ]
    5. FROM table1 [, table2 ]
    6. [WHERE])

    简单子查询(比较运算符)

    1. SELECTFROM [表名]
    2. WHERE= |= (子查询);

    IN筛选

    IN

    1. SELECTFROM [表名]
    2. WHEREIN (子查询);

    NOT IN

    1. SELECTFROM [表名]
    2. WHERENOT IN (子查询);

    SOME/ALL

    1. SELECTFROM [表名]
    2. WHERE 列 比较运算符 [ALL/SOME] (子查询);

    EXISTS

    1. SELECTFROM [表名]
    2. WHERE 列 [NOT] EXISTS 子查询

    范围筛选

    BETWEEN.AND

    注意:该子句是闭区间

    1. SELECTFROM [表名]
    2. WHEREBETWEEN 起始 AND 终止;

    NOT.BETWEEN.AND

    注意:该子句是开区间

    1. SELECTFROM [表名]
    2. WHERENOT BETWEEN 起始 AND 终止;

    查找空值

    IS NULL

    1. SELECTFROM
    2. WHEREIS NULL;

    IS NOT NULL

    1. SELECTFROM
    2. WHEREIS NOT NULL;

    连接(JOIN)

    连接说明

    如果一个 JOIN 至少有一个公共字段并且它们之间存在关系
    则该 JOIN 可以在两个或多个表上工作
    连接用于连接多个表,使用 JOIN 关键字,并且条件语句使用 ON 而不是 WHERE
    JOIN 保持基表(结构和数据)不变

    JOIN 有两种连接类型:内连接和外连接

    内连接
    又称等值连接,使用 INNER JOIN 关键字
    在没有条件语句的情况下返回笛卡尔积。
    自连接
    可以看成内连接的一种,只是连接的表是自身而已
    自然连接是把同名列通过 = 测试连接起来的,同名列可以有多个

    内连接 vs 自然连接
    内连接提供连接的列
    而自然连接自动连接所有同名列

    外连接返回一个表中的所有行,并且仅返回来自次表中满足连接条件的那些行
    即两个表中的列是相等的。外连接分为左外连接、右外连接、全外连接
    左外连接就是保留左表没有关联的行
    右外连接就是保留右表没有关联的行

    连接 vs 子查询
    连接可以替换子查询,并且比子查询的效率一般会更快

    image

    连接的具体类型

    INNER JOIN(内连接)
    Returns rows when there is a match in both tables

    LEFT JOIN(左连接)
    Returns all rows from the left table, even if there are no matches in the right table

    RIGHT JOIN(右连接)
    Returns all rows from the right table, even if there are no matches in the left table

    FULL JOIN(全连接)
    Returns rows when there is a match in one of the tables

    SELF JOIN(自连接)
    This is used to join a table to itself as if the table were two tables, temporarily renaming at least one table in the MS SQL Server statement

    CARTESIAN JOIN(笛卡尔连接)
    Returns the Cartesian product of the sets of records from the two or more joined tables

    内连接

    1. SELECT
    2. FROM
    3. 1 INNER JOIN2
    4. ON
    5. 条件;

    外连接-左

    1. SELECT
    2. FROM
    3. 1 LEFT OUTER JOIN2
    4. ON
    5. 条件;

    外连接-右

    1. SELECT
    2. FROM
    3. 1 RIGHT OUTER JOIN2
    4. ON
    5. 条件;

    全连接

    全连接:保留两表的所有行,没有对应字段的值置为null

    1. SELECT
    2. FROM
    3. 1 FULL OUTER JOIN2
    4. ON
    5. 条件;

    交叉连接

    1. SELECT
    2. FROM
    3. 1 CROSS JOIN2
    4. ON
    5. 条件;

    自连接

    1. SELECT c1.cust_id, c1.cust_name, c1.cust_contact
    2. FROM customers c1, customers c2
    3. WHERE c1.cust_name = c2.cust_name
    4. AND c2.cust_contact = 'Jim Jones';

    自然连接(NATURAL JOIN)

    1. SELECT *
    2. FROM Products
    3. NATURAL JOIN Customers;

    组合(UNION)

    UNION 运算符将两个或更多查询的结果组合起来
    并生成一个结果集,其中包含来自 UNION 中参与查询的提取行

    UNION 基本规则
    所有查询的列数和列顺序必须相同
    每个查询中涉及表的列的数据类型必须相同或兼容
    通常返回的列名取自第一个查询

    默认会去除相同行,如果需要保留相同行,使用 UNION ALL
    只能包含一个 ORDER BY 子句,并且必须位于语句的最后

    应用场景
    在一个查询中从不同的表返回结构数据
    对一个表执行多个查询,按一个查询返回数据

    JOIN vs UNION
    JOIN 中连接表的列可能不同,但在 UNION 中,所有查询的列数和列顺序必须相同
    UNION 将查询之后的行放在一起(垂直放置),但 JOIN 将查询之后的列放在一起(水平放置),即它构成一个笛卡尔积

    合并1
    注意:这种合并会删除重复行

    1. SELECT column1,column2,column3..
    2. FROM table_name1
    3. UNION
    4. SELECT column1,column2,column3..
    5. FROM table_name2

    合并2
    注意:这种合并会保留重复行

    1. SELECT column1,column2,column3..
    2. FROM table_name1
    3. UNION ALL
    4. SELECT column1,column2,column3..
    5. FROM table_name2

    DQL总结语句

    1. SELECT [ALL | DISTINCT] TOP n [PERCENT] 列....AS [别名]
    2. [INTO 表名]
    3. FROM 表 [别名],....
    4. [WHERE 条件]
    5. GROUP BY 分组字段 HAVING 分组条件
    6. [ORDER BY 排序字段 ASC | DESC];

    动态SQL

    动态SQL由完整的SQL语句组成,即:拼接SQL语句
    实例:

    1. /* 定义动态SQL */
    2. DECLARE @panda_id INT;
    3. SET @panda_id = 123;
    4. DECLARE @sql_expression VARCHAR(MAX);
    5. SET @sql_expression = 'SELECT * FROM
    6. panda_table WHERE id = ';
    7. /* 执行 */
    8. EXEC(@sql_expression + @panda_id);
  • 相关阅读:
    实现放大镜的效果
    【0101】【内存上下文】获取给定内存片(chunk)所占用的总空间
    100道最新Java面试题,常见面试题及答案汇总
    带式输送机的传动装置设计
    中国石油大学《离散数学》第二次在线作业
    基于轩禹秒杀ctfshow-RSA
    关于Greenplum为什么基于PostgreSQL而不是MySQL?
    全同态加密:GSW
    【必知必会】手把手教你配置MySQL环境变量——图文详解
    Jimmer: 一个面向Java和Kotlin的革命性ORM
  • 原文地址:https://blog.csdn.net/weixin_38304160/article/details/126068674