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

相关推荐
q***81642 小时前
MySQL:数据查询-limit
数据库·mysql
p***92482 小时前
DBeaver连接本地MySQL、创建数据库表的基础操作
数据库·mysql
JIngJaneIL3 小时前
社区互助|社区交易|基于springboot+vue的社区互助交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·社区互助
晚风吹人醒.3 小时前
缓存中间件Redis安装及功能演示、企业案例
linux·数据库·redis·ubuntu·缓存·中间件
Y***98513 小时前
DVWA靶场通关——SQL Injection篇
数据库·sql
Yawesh_best3 小时前
告别系统壁垒!WSL+cpolar 让跨平台开发效率翻倍
运维·服务器·数据库·笔记·web安全
蒋士峰DBA修行之路3 小时前
实验二十八 SQL PATCH调优
数据库·sql·gaussdb
I***t7164 小时前
一条sql 在MySQL中是如何执行的
数据库·sql·mysql
一 乐4 小时前
应急知识学习|基于springboot+vue的应急知识学习系统(源码+数据库+文档)
数据库·vue.js·spring boot
微学AI5 小时前
内网穿透的应用-突破局域网束缚,MongoDB 远程访问使用cpolar原来可以这么简单
数据库·mongodb