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语句集。

相关推荐
小白跃升坊1 小时前
MaxKB 使用 MCP 连接 Oracle (免安装 cx_Oracle 和 Oracle Instant Client)
数据库·oracle·maxkb·mcp
sonrisa_2 小时前
虚拟机磁盘扩容
数据库
代码的余温2 小时前
Redis Stream:高性能消息队列核心原理揭秘
数据库·redis·bootstrap
啊森要自信2 小时前
【QT】常⽤控件详解(四)常用显示类控件类 Label && LCDNumber && ProgressBar && Calendar Widget
开发语言·数据库·c++·qt·qt6.3
码明7 小时前
42.MySQL视图
数据库·oracle
山茶花开时。7 小时前
[Oracle] TO_NUMBER()函数
数据库·oracle
耳东哇8 小时前
阿里云百炼平台创建智能体-上传文档
数据库·redis·阿里云
鸿乃江边鸟9 小时前
Starrocks中的 Query Profile以及explain analyze及trace命令中的区别
大数据·starrocks·sql
ykuaile_h810 小时前
MySQL梳理三:查询与优化
数据库·mysql
掘根10 小时前
【Redis】string字符串
数据结构·数据库·redis