SQL 语法学习详细指南

SQL(Structured Query Language, 结构化查询语言)是一种用于管理和操作关系数据库的标准语言。无论是在数据分析、软件开发还是数据库管理中,SQL 都扮演着至关重要的角色。本详细指南将系统地介绍SQL的基本语法和常用操作,涵盖数据查询、数据操作、数据定义和数据控制等关键方面。SQL指南更多内容,请查询

什么是SQL?

SQL由IBM在1970年代开发,并被多家数据库系统(如MySQL、PostgreSQL、SQL Server、Oracle)采用和扩展。通过SQL,可以执行以下操作:

  1. 查询数据
  2. 插入、更新和删除数据
  3. 创建和修改数据库结构
  4. 访问和控制数据库权限

SQL 基本语法

1. 数据查询(SELECT)

数据查询是SQL中最常用的操作。SELECT语句用于从数据库中检索数据。

基本语法:

复制代码
SELECT column1, column2, ...
FROM table_name
WHERE condition(s)
ORDER BY column1 [ASC|DESC];

示例:

复制代码
SELECT first_name, last_name
FROM employees
WHERE department = 'Sales'
ORDER BY last_name ASC;

常用操作

  • 选择所有列

    复制代码
    SELECT * FROM employees;
  • 限制结果数量

    复制代码
    SELECT first_name, last_name FROM employees LIMIT 10;
  • 使用别名

    复制代码
    SELECT first_name AS fname, last_name AS lname FROM employees;
2. 数据过滤(WHERE)

WHERE 子句用于根据特定条件过滤数据。

基本语法:

复制代码
SELECT column1, column2
FROM table_name
WHERE condition;

示例:

复制代码
SELECT first_name, last_name
FROM employees
WHERE salary > 50000 AND department = 'Sales';

常用操作

  • 逻辑运算符AND, OR, NOT

    复制代码
    SELECT * FROM products WHERE price > 100 AND category = 'Electronics';
  • 比较运算符=, !=, >, <, >=, <=

    复制代码
    SELECT * FROM students WHERE age >= 18;
  • 范围与模式匹配BETWEEN, LIKE

    复制代码
    SELECT * FROM orders WHERE order_date BETWEEN '2023-01-01' AND '2023-12-31';
    SELECT * FROM users WHERE email LIKE '%example.com';
3. 数据聚合(GROUP BY)

GROUP BY 将行数据组合到汇总行中,通常与聚合函数(如COUNTSUMAVGMAXMIN)一起使用。

基本语法:

复制代码
SELECT column1, AGGREGATE_FUNCTION(column2)
FROM table_name
WHERE condition
GROUP BY column1;

示例:

复制代码
SELECT department, COUNT(*) AS num_employees
FROM employees
WHERE salary > 50000
GROUP BY department;
4. 数据排序(ORDER BY)

ORDER BY 子句用于对结果集排序,可以按升序(ASC)或降序(DESC)排序。

基本语法:

复制代码
SELECT column1, column2
FROM table_name
ORDER BY column1 [ASC|DESC];

示例:

复制代码
SELECT first_name, last_name
FROM employees
ORDER BY last_name DESC;
5. 连接(JOIN)

JOIN 操作用于根据相关列将来自两个或多个表中的记录组合。

常见的JOIN类型

  • 内连接(INNER JOIN)

    复制代码
    SELECT orders.order_id, customers.customer_name
    FROM orders
    INNER JOIN customers ON orders.customer_id = customers.customer_id;
  • 左连接(LEFT JOIN)

    复制代码
    SELECT orders.order_id, customers.customer_name
    FROM orders
    LEFT JOIN customers ON orders.customer_id = customers.customer_id;
  • 右连接(RIGHT JOIN)

    复制代码
    SELECT orders.order_id, customers.customer_name
    FROM orders
    RIGHT JOIN customers ON orders.customer_id = customers.customer_id;
  • 全连接(FULL OUTER JOIN)

    复制代码
    SELECT orders.order_id, customers.customer_name
    FROM orders
    FULL OUTER JOIN customers ON orders.customer_id = customers.customer_id;
6. 子查询(Subquery)

子查询是嵌套在其他查询(如SELECTINSERTUPDATEDELETE语句)中的查询,可以返回单条或多条数据。

基本语法:

复制代码
SELECT column1
FROM table_name
WHERE column2 = (SELECT column FROM table_name WHERE condition);

示例:

复制代码
SELECT employee_id, first_name, last_name
FROM employees
WHERE department_id = (SELECT department_id FROM departments WHERE department_name = 'Sales');
7. 插入数据(INSERT)

INSERT 语句用于将新记录插入到表中。

基本语法:

复制代码
INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...);

示例:

复制代码
INSERT INTO employees (first_name, last_name, department, salary) 
VALUES ('John', 'Doe', 'Sales', 60000);
8. 更新数据(UPDATE)

UPDATE 语句用于修改表中的现有记录。

基本语法:

复制代码
UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

示例:

复制代码
UPDATE employees
SET salary = 70000
WHERE employee_id = 123;
9. 删除数据(DELETE)

DELETE 语句用于删除表中的记录。

基本语法:

复制代码
DELETE FROM table_name
WHERE condition;

示例:

复制代码
DELETE FROM employees
WHERE employee_id = 123;
10. 创建和修改表(CREATE TABLE / ALTER TABLE)

CREATE TABLE 用于创建新表,ALTER TABLE 用于修改现有表。

创建表基本语法:

复制代码
CREATE TABLE table_name (
    column1 datatype constraints,
    column2 datatype constraints,
    ...
);

示例:

复制代码
CREATE TABLE employees (
    employee_id INT PRIMARY KEY,
    first_name VARCHAR(50),
    last_name VARCHAR(50),
    department VARCHAR(50),
    salary DECIMAL(10, 2)
);

修改表基本语法:

复制代码
ALTER TABLE table_name
ADD column_name datatype;

示例:

复制代码
ALTER TABLE employees
ADD hire_date DATE;
11. 数据库权限和用户管理(GRANT / REVOKE)

管理数据库权限和用户是确保数据安全的关键部分。

创建用户基本语法:

复制代码
CREATE USER 'username'@'host' IDENTIFIED BY 'password';

示例:

复制代码
CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'user_password';

授予权限基本语法:

复制代码
GRANT privilege ON database.table TO 'username'@'host';

示例:

复制代码
GRANT SELECT, INSERT ON mydatabase.* TO 'newuser'@'localhost';

撤销权限基本语法:

复制代码
REVOKE privilege ON database.table FROM 'username'@'host';

示例:

复制代码
REVOKE INSERT ON mydatabase.* FROM 'newuser'@'localhost';
结论

SQL 是强大而灵活的数据库管理和操作语言。通过本详细指南,您已经掌握了SQL的基本语法和常见操作,包括数据查询、数据操作、数据定义和数据控制。熟练掌握这些基础知识,无论是进行数据分析、应用开发还是数据库管理,都能够得心应手。

如果您希望进一步深入学习,可以参考以下资源:

希望这篇指南对您有所帮助。如果有任何疑问或需要进一步详细解释的内容,请随时提问。

相关推荐
m0_613856293 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios7944 小时前
VPR:Pitts50K和Norland数据集下载
数据库
东风破1374 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
收获不止数据库4 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
小宇的天下4 小时前
Virtuoso GUI 界面中的关键模块定义
数据库
我的xiaodoujiao4 小时前
API 接口自动化测试详细图文教程学习系列16--项目实战演练3
python·学习·测试工具·pytest
bqq198610264 小时前
MySQL 5.7 与 MySQL 8.0 的主要区别
数据库·mysql
juniperhan4 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
Elastic 中国社区官方博客5 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索
复利人生 复利日知录 赋能循环5 小时前
2026年复利精进:我的每日觉醒与成长密码
学习·思维模型·知识复利·复利·独立