这是一份SQL Server查询语句的全面集合,为数据库管理和查询操作提供了丰富多样的语句资源。
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 的查询语句,包括基础查询、条件查询、分组查询、连接查询和子查询等,通过实战案例,您可以更好地理解这些查询语句在实际工作中的应用,掌握这些查询技巧,将有助于提高您的数据库管理和数据分析能力,在实际工作中,您可以根据需求灵活运用这些查询语句,以满足不同的业务场景。
原创文章,作者:酷盾叔,如若转载,请注明出处:https://www.kdun.com/ask/236588.html
本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。
发表回复