SQL语句

SQL(Structured Query Language,结构化查询语言)是用于管理和操作关系数据库系统的标准编程语言。它允许用户执行数据的定义、查询、更新和管理等操作。以下是一些常见的SQL语句及其简要说明:

数据定义语言(DDL)

DDL语句用于定义和管理数据库中的数据结构或模式。

• CREATE:创建数据库对象(如表、索引、视图等)。

【sql】

复制代码
 CREATE TABLE employees (
      id INT PRIMARY KEY,
      name VARCHAR(100),
      position VARCHAR(50),
      salary DECIMAL(10, 2)
  );

• ALTER:修改现有数据库对象的结构。

【sql】

复制代码
 ALTER TABLE employees ADD COLUMN department VARCHAR(50);

• DROP:删除数据库对象。

【sql】

复制代码
 DROP TABLE employees;

• TRUNCATE:清空表中的所有数据,但保留表结构。

【sql】

复制代码
 TRUNCATE TABLE employees;

数据操作语言(DML)

DML语句用于查询、插入、更新和删除数据库中的数据。

• SELECT:从数据库中检索数据。

【sql】

复制代码
 SELECT name, position FROM employees WHERE salary > 50000;

• INSERT:向数据库中插入新数据。

【sql】

复制代码
 INSERT INTO employees (id, name, position, salary) VALUES (1, 'John Doe', 'Manager', 60000);

• UPDATE:修改数据库中的现有数据。

【sql】

复制代码
 UPDATE employees SET salary = 65000 WHERE id = 1;

• DELETE:从数据库中删除数据。

【sql】

复制代码
 DELETE FROM employees WHERE id = 1;

数据查询语言(DQL,实际上是DML的一部分)

虽然DQL不是严格意义上的SQL分类,但通常将SELECT语句视为DQL,因为它专门用于数据查询。

数据控制语言(DCL)

DCL语句用于设置或更改数据库用户权限和安全级别。

• GRANT:授予用户访问权限。

【sql】

复制代码
 GRANT SELECT, INSERT ON employees TO some_user;

• REVOKE:收回用户访问权限。

【sql】

复制代码
 REVOKE INSERT ON employees FROM some_user;

事务控制语言(TCL)

TCL语句用于管理数据库事务,确保数据的一致性和完整性。

• START TRANSACTION或BEGIN:开始一个新的事务。

【sql】

复制代码
 BEGIN;

• COMMIT:提交事务,使所有更改永久生效。

【sql】

复制代码
 COMMIT;

• ROLLBACK:回滚事务,撤销自上次提交以来的所有更改。

【sql】

复制代码
 ROLLBACK;

• SAVEPOINT:设置事务中的保存点,以便可以回滚到该点。

【sql】

复制代码
 SAVEPOINT savepoint_name;

• SET TRANSACTION:设置事务的属性,如隔离级别。

【sql】

复制代码
 SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;

这些SQL语句是关系数据库管理系统(RDBMS)的基础,不同的RDBMS(如MySQL、PostgreSQL、Oracle、SQL Server等)可能在SQL标准的实现上有所不同,但大多数都支持上述基本的SQL语句集。

相关推荐
篱笆院的狗16 分钟前
MySQL 中如何进行 SQL 调优?
java·sql·mysql
SelectDB技术团队1 小时前
顺丰科技:从 Presto 到 Doris 湖仓构架升级,提速 3 倍,降本 48%
大数据·数据库·数据仓库·信息可视化·数据分析·doris·实时分析
wangbaowo1 小时前
MySQL数据库下篇
数据库·经验分享·笔记·学习·mysql·安全
ABdolphin1 小时前
Spring-博客系统项目
数据库·sql·spring
伤不起bb1 小时前
MySQl 数据库操作
数据库·mysql
是店小二呀2 小时前
【金仓数据库征文】金仓数据库(KingbaseES)迁移与集群部署实战:从MySQL到KES的全流程解析
数据库·mysql·金仓数据库 2025 征文·数据库平替用金仓
一只专注api接口开发的技术猿2 小时前
1688 API 自动化采集实践:商品详情实时数据接口开发与优化
大数据·运维·数据库·自动化
昔我往昔2 小时前
MySQL中为什么使用B+树结构、B+树和普通的平衡树的区别
数据库·b树·mysql
翁正存3 小时前
MySQL为什么选择B+树
数据库·b树·mysql
码农黛兮_463 小时前
MySQL 数据库集群部署、性能优化及高可用架构设计
数据库·mysql·性能优化