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

相关推荐
fen_fen8 小时前
Oracle建表语句示例
数据库·oracle
砚边数影10 小时前
数据可视化入门:Matplotlib 基础语法与折线图绘制
数据库·信息可视化·matplotlib·数据可视化·kingbase·数据库平替用金仓·金仓数据库
orange_tt10 小时前
Djiango配置Celery
数据库·sqlite
云小逸11 小时前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
肉包_51111 小时前
两个数据库互锁,用全局变量互锁会偶发软件卡死
开发语言·数据库·c++
霖霖总总11 小时前
[小技巧64]深入解析 MySQL InnoDB 的 Checkpoint 机制:原理、类型与调优
数据库·mysql
此刻你12 小时前
常用的 SQL 语句
数据库·sql·oracle
それども13 小时前
分库分表的事务问题 - 怎么实现事务
java·数据库·mysql
·云扬·13 小时前
MySQL Binlog 配置指南与核心作用解析
数据库·mysql·adb
天空属于哈夫克313 小时前
Java 版:利用外部群 API 实现自动“技术开课”倒计时提醒
数据库·python·mysql