SQL Server 语句的语法通常遵循以下结构:
SELECT [列名1, 列名2, ...] FROM [表名或视图名] WHERE [条件表达式] GROUP BY [分组列名] HAVING [分组筛选条件] ORDER BY [排序列名] [ASC|DESC];
SELECT
子句:用于指定要从查询中返回的列。可以使用*
来选择所有列。FROM
子句:用于指定要查询的表或视图。WHERE
子句(可选):用于过滤查询结果,只返回满足条件的行。GROUP BY
子句(可选):用于对查询结果进行分组,通常与聚合函数(如 COUNT、SUM、AVG 等)一起使用。HAVING
子句(可选):用于过滤分组后的结果,只返回满足条件的分组。ORDER BY
子句(可选):用于对查询结果进行排序。可以指定ASC
(升序,默认值)或DESC
(降序)。
以下是一个简单的 SQL Server 查询示例:
SELECT EmployeeID, FirstName, LastName, Salary FROM Employees WHERE DepartmentID = 10 GROUP BY EmployeeID, FirstName, LastName, Salary HAVING AVG(Salary) > 50000 ORDER BY LastName ASC;
这个查询将从 Employees
表中选择 EmployeeID
、FirstName
、LastName
和 Salary
列,只返回属于部门 ID 为 10 的员工,并且按照薪水分组,只显示平均薪水大于 50,000 的分组。最后,结果按照姓氏升序排列。