SQL Server2008 select语句基本语法

SELECT 语句基本语法

SQL Server 中的 SELECT 语句用于从数据库中检索数据。基本语法如下:

sql 复制代码
SELECT 查询内容  
FROM 表名  
[WHERE 条件表达式]   
[GROUP BY 待分组的列名]  
[HAVING condition]  
[ORDER BY 待排序的列名 [ASC | DESC]] 

查询所有列

检索表中的所有列可以使用 *

sql 复制代码
SELECT *  
FROM employees;  

查询特定列

仅选择需要的列:

sql 复制代码
SELECT first_name, last_name, salary  
FROM employees;  

使用 WHERE 子句过滤数据

WHERE 子句用于筛选符合条件的记录:

sql 复制代码
SELECT employee_id, first_name, last_name  
FROM employees  
WHERE salary > 50000;  

使用 ORDER BY 排序

ORDER BY 用于对结果进行升序(ASC)或降序(DESC)排序:

sql 复制代码
SELECT employee_id, first_name, last_name  
FROM employees  
ORDER BY last_name ASC;  

使用 GROUP BY 分组

GROUP BY 用于对数据进行分组,通常与聚合函数(如 COUNTSUMAVG)一起使用:

sql 复制代码
SELECT department_id, COUNT(*) AS employee_count  
FROM employees  
GROUP BY department_id;  

使用 HAVING 筛选分组

HAVING 子句用于对分组后的数据进行筛选:

sql 复制代码
SELECT department_id, AVG(salary) AS avg_salary  
FROM employees  
GROUP BY department_id  
HAVING AVG(salary) > 60000;  

使用 DISTINCT 去重

DISTINCT 用于返回唯一不同的值:

sql 复制代码
SELECT DISTINCT department_id  
FROM employees;  

使用 TOP 限制返回行数

SQL Server 使用 TOP 限制查询返回的行数:

sql 复制代码
SELECT TOP 10 employee_id, first_name, last_name  
FROM employees  
ORDER BY salary DESC;  

使用别名提高可读性

列或表可以使用别名(AS 可省略):

sql 复制代码
SELECT first_name AS "First Name", last_name AS "Last Name"  
FROM employees AS e;  

使用 JOIN 关联表

JOIN 用于从多个表中检索数据:

sql 复制代码
SELECT e.first_name, e.last_name, d.department_name  
FROM employees e  
JOIN departments d ON e.department_id = d.department_id;  

使用子查询

子查询可以嵌套在 SELECT 语句中:

sql 复制代码
SELECT employee_id, first_name, last_name  
FROM employees  
WHERE department_id IN (SELECT department_id FROM departments WHERE location_id = 1700);  

这些基本语法涵盖了 SQL Server 中 SELECT 语句的常见用法,适用于大多数数据检索需求。

相关推荐
ccddsdsdfsdf4 小时前
DBeaver怎么链接mongoDB
数据库·mongodb
丷丩5 小时前
Postgresql基础实践教程(十一)各种Join
数据库·postgresql·join
星夜夏空995 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
TheRouter6 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle
Omics Pro6 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
唐青枫6 小时前
MySQL EXISTS 详解:存在性判断、NOT EXISTS 与实战示例
sql·mysql
JAVA面经实录9177 小时前
Hibernate面试题库
数据库·oracle·hibernate
迷枫7128 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
Mr.Daozhi9 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_809 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体