SQL语言:DDL、DML、DQL、DCL详解

简介: SQL程序语言有四种类型,对数据库的基本操作都属于这四类,它们分别为;数据定义语言(DDL)、数据查询语言(DQL)、数据操纵语言(DML)、数据控制语言(DCL)

前言


SQL程序语言有四种类型,对数据库的基本操作都属于这四类,它们分别为;数据定义语言(DDL)、数据查询语言(DQL)、数据操纵语言(DML)、数据控制语言(DCL)


数据定义语言(DDL)



DDL全称是Data Definition Language,即数据定义语言,定义语言就是定义关系模式、删除关系、修改关系模式以及创建数据库中的各种对象,比如表、聚簇、索引、视图、函数、存储过程和触发器等等。


数据定义语言是由SQL语言集中负责数据结构定义与数据库对象定义的语言,并且由CREATE、ALTER、DROP和TRUNCATE四个语法组成。比如:


--创建一个student表
    create table student(
     id int identity(1,1) not null,
     name varchar(20) null,
     course varchar(20) null,
     grade numeric null
    )
复制代码


--student表增加一个年龄字段
    alter table student add age int NULL
复制代码


--student表删除年龄字段,删除的字段前面需要加column,不然会报错,而添加字段不需要加column
    alter table student drop Column age
复制代码


--删除student表
    drop table student --删除表的数据和表的结构
    truncate table student -- 只是清空表的数据,,但并不删除表的结构,student表还在只是数据为空
复制代码


数据操纵语言(DML)


数据操纵语言全程是Data Manipulation Language,主要是进行插入元组、删除元组、修改元组的操作。主要有insert、update、delete语法组成。


--向student表中插入数据
    --数据库插入数据 一次性插入多行多列 格式为INSERT INTO table (字段1, 字段2,字段3) VALUES (值1,值2,值3),(值1,值2,值3),...;
    INSERT INTO student (name, course,grade) VALUES ('张飞','语文',90),('刘备','数学',70),('关羽','历史',25),('张云','英语',13);
复制代码


--更新关羽的成绩
    update student set grade='18' where name='关羽'
复制代码


--关羽因为历史成绩太低,要退学,所以删除关羽这个学生
    delete from student where name='关羽'
复制代码


数据查询语言(DQL)


数据查询语言全称是Data Query Language,所以是用来进行数据库中数据的查询的,即最常用的select语句


--从student表中查询所有的数据
    select * from student
复制代码


--从student表中查询姓名为张飞的学生
    select * from student where name='张飞'
复制代码


数据控制语言(DCL)


数据控制语言:Data Control Language。用来授权或回收访问数据库的某种特权,并控制数据库操纵事务发生的时间及效果,能够对数据库进行监视。


比如常见的授权、取消授权、回滚、提交等等操作。


1、创建用户


语法结构:


CREATE USER 用户名@地址 IDENTIFIED BY '密码';
    --创建一个testuser用户,密码111111
    create user testuser@localhost identified by '111111';
复制代码


2、给用户授权


     语法结构:


GRANT 权限1, … , 权限n ON 数据库.对象  TO 用户名;
    --将test数据库中所有对象(表、视图、存储过程,触发器等。*表示所有对象)的create,alter,drop,insert,update,delete,select赋给testuser用户
    grant create,alter,drop,insert,update,delete,select on test.* to testuser@localhost;
复制代码


3、撤销授权


语法结构:


REVOKE权限1, … , 权限n ON 数据库.对象 FORM 用户名;
--将test数据库中所有对象的create,alter,drop权限撤销
revoke create,alter,drop on test.* to testuser@localhost;
复制代码


4、查看用户权限


语法结构:


SHOW GRANTS FOR 用户名;
 --查看testuser的用户权限
 show grants for testuser@localhost;
复制代码


5、删除用户


语法结构:


DROP USER 用户名;
--删除testuser用户
drop user testuser@localhost;
复制代码


6、修改用户密码


语法结构:


USE mysql;
UPDATE USER SET PASSWORD=PASSWORD(‘密码’) WHERE User=’用户名’ and Host=’IP’;
FLUSH PRIVILEGES;
--将testuser的密码改为123456
update user set password=password('123456') where user='testuser' and host=’localhost’;
FLUSH PRIVILEGES;
复制代码


结尾


本文对SQL程序语言有四种操作语言做了一个简单的介绍和概括,对数据库的基本操作都属于这四类,它们分别为;数据定义语言(DDL)、数据查询语言(DQL)、数据操纵语言(DML)、数据控制语言(DCL)  。

目录
相关文章
|
24天前
|
SQL 流计算
Flink(十三)【Flink SQL(上)SqlClient、DDL、查询】(4)
Flink(十三)【Flink SQL(上)SqlClient、DDL、查询】
|
24天前
|
SQL Java 流计算
Flink(十三)【Flink SQL(上)SqlClient、DDL、查询】(3)
Flink(十三)【Flink SQL(上)SqlClient、DDL、查询】
|
4天前
|
SQL Oracle 关系型数据库
技术经验解读:【读书笔记】SQL语言基础
技术经验解读:【读书笔记】SQL语言基础
|
10天前
|
SQL 关系型数据库 MySQL
零基础学习数据库SQL语句之定义数据库对象的DDL语句
零基础学习数据库SQL语句之定义数据库对象的DDL语句
14 0
|
SQL 关系型数据库 PostgreSQL
PostgreSQL 10.1 手册_部分 I. 教程_第 2 章 SQL语言
第 2 章 SQL语言 目录 2.1. 引言 2.2. 概念 2.3. 创建一个新表 2.4. 在表中增加行 2.5. 查询一个表 2.6. 在表之间连接 2.7. 聚集函数 2.
1027 0
|
SQL 关系型数据库 PostgreSQL
PostgreSQL 10.1 手册_部分 I. 教程_第 2 章 SQL语言_2.9. 删除
2.9. 删除 数据行可以用DELETE命令从表中删除。假设你对Hayward的天气不再感兴趣,那么你可以用下面的方法把那些行从表中删除: DELETE FROM weather WHERE city = 'Hayward'; 所有属于Hayward的天气记录都被删除。
1127 0
|
SQL 关系型数据库 PostgreSQL
PostgreSQL 10.1 手册_部分 I. 教程_第 2 章 SQL语言_2.8. 更新
2.8. 更新 你可以用UPDATE命令更新现有的行。假设你发现所有 11 月 28 日以后的温度读数都低了两度,那么你就可以用下面的方式改正数据: UPDATE weather SET temp_hi = temp_hi - 2, temp_lo = temp_lo - 2 .
1135 0
|
SQL 关系型数据库 PostgreSQL
PostgreSQL 10.1 手册_部分 I. 教程_第 2 章 SQL语言_2.7. 聚集函数
2.7. 聚集函数 和大多数其它关系数据库产品一样,PostgreSQL支持聚集函数。 一个聚集函数从多个输入行中计算出一个结果。 比如,我们有在一个行集合上计算count(计数)、sum(和)、avg(均值)、max(最大值)和min(最小值)的函数。
1150 0
|
SQL 关系型数据库 PostgreSQL
PostgreSQL 10.1 手册_部分 I. 教程_第 2 章 SQL语言_2.6. 在表之间连接
2.6. 在表之间连接 到目前为止,我们的查询一次只访问一个表。查询可以一次访问多个表,或者用这种方式访问一个表而同时处理该表的多个行。 一个同时访问同一个或者不同表的多个行的查询叫连接查询。举例来说,比如你想列出所有天气记录以及相关的城市位置。
1222 0
|
SQL 关系型数据库 PostgreSQL
PostgreSQL 10.1 手册_部分 I. 教程_第 2 章 SQL语言_2.5. 查询一个表
2.5. 查询一个表 要从一个表中检索数据就是查询这个表。SQL的SELECT语句就是做这个用途的。 该语句分为选择列表(列出要返回的列)、表列表(列出从中检索数据的表)以及可选的条件(指定任意的限制)。
1105 0