当前位置:首页 > 行业动态 > 正文

SQL Server查询语句大全集锦

这是一份SQL Server查询语句的全面集合,为数据库管理和查询操作提供了丰富多样的语句资源。

SQL Server查询语句大全集锦  第1张

SQL Server查询语句大全:技巧与实战案例分享

概述

SQL Server 是一个广泛使用的数据库管理系统,其查询语句是数据库操作的核心,掌握各种查询语句对于数据库管理和数据分析至关重要,本文将为您详细介绍 SQL Server 的常用查询语句,包括基础查询、条件查询、分组查询、连接查询等,并通过实战案例分享,帮助您在实际工作中更加高效地使用 SQL Server。

基础查询

1、查询所有列

SELECT * FROM 表名;

2、查询指定列

SELECT 列1, 列2, ..., 列n FROM 表名;

3、查询指定列并指定别名

SELECT 列1 AS 别名1, 列2 AS 别名2, ..., 列n AS 别名n FROM 表名;

4、查询去重数据

SELECT DISTINCT 列名 FROM 表名;

条件查询

1、简单条件查询

SELECT * FROM 表名 WHERE 列名 = 值;

2、逻辑运算符条件查询

SELECT * FROM 表名 WHERE 列名1 = 值1 AND 列名2 = 值2;
SELECT * FROM 表名 WHERE 列名1 = 值1 OR 列名2 = 值2;
SELECT * FROM 表名 WHERE NOT (列名 = 值);

3、模糊查询

SELECT * FROM 表名 WHERE 列名 LIKE '通配符表达式';

通配符:% 表示任意个字符,_ 表示一个字符。

SELECT * FROM Students WHERE Name LIKE '张%';
SELECT * FROM Students WHERE Name LIKE '张_';

4、范围查询

SELECT * FROM 表名 WHERE 列名 BETWEEN 值1 AND 值2;

5、IN 查询

SELECT * FROM 表名 WHERE 列名 IN (值1, 值2, ..., 值n);

6、NULL 值查询

SELECT * FROM 表名 WHERE 列名 IS NULL;
SELECT * FROM 表名 WHERE 列名 IS NOT NULL;

分组查询

1、GROUP BY 分组查询

SELECT 列名, 聚合函数 FROM 表名 GROUP BY 列名;
SELECT DepartmentID, COUNT(*) AS Total FROM Employees GROUP BY DepartmentID;

2、HAVING 子句

HAVING 子句用于对分组后的结果进行条件筛选。

SELECT 列名, 聚合函数 FROM 表名 GROUP BY 列名 HAVING 聚合函数条件;
SELECT DepartmentID, COUNT(*) AS Total FROM Employees GROUP BY DepartmentID HAVING COUNT(*) > 5;

连接查询

1、INNER JOIN 内连接

内连接查询两个表中有匹配的记录。

SELECT A.列名, B.列名 FROM 表A INNER JOIN 表B ON A.关联列 = B.关联列;

2、LEFT JOIN 左连接

左连接查询左表所有记录和右表中匹配的记录。

SELECT A.列名, B.列名 FROM 表A LEFT JOIN 表B ON A.关联列 = B.关联列;

3、RIGHT JOIN 右连接

右连接查询右表所有记录和左表中匹配的记录。

SELECT A.列名, B.列名 FROM 表A RIGHT JOIN 表B ON A.关联列 = B.关联列;

4、FULL JOIN 全连接

全连接查询左表和右表中的所有记录。

SELECT A.列名, B.列名 FROM 表A FULL JOIN 表B ON A.关联列 = B.关联列;

子查询

子查询是嵌套在另一个查询中的查询。

1、WHERE 子句中的子查询

SELECT * FROM 表名 WHERE 列名 = (SELECT 列名 FROM 另一个表 WHERE 条件);

2、FROM 子句中的子查询

SELECT * FROM (SELECT 列名 FROM 另一个表 WHERE 条件) AS 子查询别名;

3、SELECT 子句中的子查询

SELECT 列名, (SELECT 列名 FROM 另一个表 WHERE 条件) AS 子查询别名 FROM 表名;

实战案例

1、查询各部门平均工资

SELECT DepartmentID, AVG(Salary) AS AverageSalary FROM Employees GROUP BY DepartmentID;

2、查询各部门工资最高的员工

SELECT DepartmentID, MAX(Salary) AS MaxSalary FROM Employees GROUP BY DepartmentID;

3、查询员工及其部门名称

SELECT e.EmployeeID, e.Name, d.DepartmentName FROM Employees e INNER JOIN Departments d ON e.DepartmentID = d.DepartmentID;

4、查询没有订单的顾客

SELECT c.CustomerID, c.Name FROM Customers c LEFT JOIN Orders o ON c.CustomerID = o.CustomerID WHERE o.CustomerID IS NULL;

5、查询工资排名前五的员工

SELECT TOP 5 EmployeeID, Name, Salary FROM Employees ORDER BY Salary DESC;

本文为您详细介绍了 SQL Server 的查询语句,包括基础查询、条件查询、分组查询、连接查询和子查询等,通过实战案例,您可以更好地理解这些查询语句在实际工作中的应用,掌握这些查询技巧,将有助于提高您的数据库管理和数据分析能力,在实际工作中,您可以根据需求灵活运用这些查询语句,以满足不同的业务场景。

0