数据库(七)-Data Manipulation Language:数据操作语言

本文深入讲解了SQL数据操作语言(DML)的三大核心功能:插入、修改和删除数据。通过实例演示了如何使用INSERT语句插入单条或多条记录,UPDATE语句修改特定或所有记录,以及DELETE语句删除满足条件的记录。

DML:数据操作语言

数据操作在SQL主要是操作表中的数据,使用DML可以完成以下三个操作:

  • 插入数据
  • 修改数据
  • 删除数据

下面我们来简单介绍一下DML的三种功能语句。

一、插入数据

在向数据表插入数据时,可以输用以下语句:

INSERT INTO 表名(l1, l2, ........) VALUE (c1, c2, .....);
/*其中li(i = 1, 2, ....)为表中的列名,ci(i = 1, 2, .....)表示要插入数据的内容*/

在使用VALUE关键字的时候,每条语句只能插入一条数据,如果需要使用一条语句插入多行记录,需要使用VALUES关键字。(这种指定列名插入的方式,可以选择表中的若干列进行记录的插入操作,未进行数据插入的列将赋值为MySQL的默认值’(null)’)
例如,我们想在‘dept’表中插入多行记录,可以这样编写SQL语句:

INSERT  INTO dept(deptno,dname,loc) VALUES (10,'教研部','北京'),(20,'学工部','上海'),(30,'销售部','广州');
/*多行记录之间要用‘,’隔开*/

使用插入语句时,也可以不指定插入的列名,但必须将每一列的数据按照表中列名顺序依次填写,否则DBMS会报错,例如,我们想在‘dept’表中插入一行记录,可以这样编写SQL语句:

INSERT  INTO dept VALUES (10,'教研部','北京');

在进行插入操作时,不确定的列可以赋值为_null_,所有字符串赋值使用单引号。


+

WHERE字句

在介绍SQL语句的修改和删除语句之前,我们需要先了解SQL语句的条件选择子句:WHERE子句。

  • WHERE选择子句的作用是在主句中有选择的选取数据,相当于Java语言中的_if_语句;
  • WHERE子句的语法很简单:WHERE 列 运算符 值;
  • WHERE子句中常用的运算符有:
运算符描述
=等于
<>不等于
>大于
<小于
>=大于等于
<=小于等于
BETWEEN a AND b在(a, b)范围内
LIKE搜索某种模式
IS NULL数据为(null)
NOT
AND逻辑与
OR逻辑或

先简单介绍一下WHERE条件子句,具体用法会在后面的文章中具体介绍

二、修改数据

《数据库(六)》中简单介绍了表结构修改的数据库语句,但我们在实际开发中一般不会轻易的去修改已经建好的数据表的结构,因为那样会引起一系列的连锁反应,像前后端代码可能会有较大的变动,对开发造成不良影响。相对与表结构的修改,我们在实际开发中用的比较多的是对表中数据的修改,下面我们介绍一下对MySQL数据库表中数据修改的SQL语句。

基本语法:

UPDATE 表名 SET col1 = value1, col2 = value2... WHERE ...;

其中WHERE语句为可选选项,如果不添加WHERE子句,那么表中所有记录的col1col2字段的值都会被修改为value1value2

例如,我们有一个dept表,里面存储的是公司各个部门及其信息,如下图:
dept数据表
如果我们不加WHERE子句就对表中数据修改,我们以修改deptmo为例,在非安全模式下,可以执行以下语句:

UPDATE dept SET deptno = 10; /*不建议使用该语句*/

在MySQL中,如果执行上述语句会对表中所有数据进行修改,但在MySQL系统中,设计者为了避免开发人员的某些事物导致执行数据修改以及数据删除过程中未添加限制条件,导致整个数据表中的数据全部被修改或删除,设计了一种安全模式,这种模式使用SQL_SAFE_UPDATES参数标识是否使用该模式,参数值为1时,启动该模式,为0时禁用该模式。
这里我们先不做过多介绍。
下面我们使用带WHERE子句的SQL语句进行表的数据值修改操作;执行下面的语句:

/*将loc字段值为'武汉'的记录改为loc='杭州'*/
UPDATE dept SET loc = '杭州' WHERE loc = '武汉';

记录更新后的表记录:
数据修改后的表

三、删除数据

基本语法为:

DELETE FROM 表名 WHERE ...

使用方法和修改数据语句相同,其基本作用是在指定表中删除满足WHERE条件的记录。


以上就是数据操作语言的基本内容。

### 数据操作语言(DML)定义数据库记录(数据) 数据操作语言Data Manipulation Language,DML)主要用于对数据库中的数据进行操作,常见的操作包括插入、更新和删除等,这些操作都是围绕数据库记录(数据)展开的。 #### 插入数据(INSERT) INSERT 语句用于向数据库表中插入新的记录。例如,在一个名为 `students` 的表中插入一条新记录: ```sql INSERT INTO students (student_id, name, age) VALUES (1, 'John Doe', 20); ``` 上述 SQL 语句向 `students` 表中插入了一条记录,包含 `student_id`、`name` 和 `age` 三个字段的值。 #### 更新数据(UPDATE) UPDATE 语句用于修改数据库表中已有的记录。例如,将 `students` 表中 `student_id` 为 1 的记录的 `age` 字段更新为 21: ```sql UPDATE students SET age = 21 WHERE student_id = 1; ``` 这里使用 `WHERE` 子句来指定要更新的记录的条件。 #### 删除数据(DELETE) DELETE 语句用于从数据库表中删除记录。例如,删除 `students` 表中 `student_id` 为 1 的记录: ```sql DELETE FROM students WHERE student_id = 1; ``` 同样,`WHERE` 子句用于指定要删除的记录的条件。 ### 数据控制语言(DCL) 数据控制语言Data Control Language,DCL)主要用于控制对数据库的访问权限和事务处理。 #### 权限管理 DCL 中最常见的操作是授予和撤销用户对数据库对象(如表、视图等)的权限。 ##### 授予权限(GRANT) GRANT 语句用于向用户或角色授予特定的权限。例如,授予用户 `user1` 对 `students` 表的 `SELECT` 权限: ```sql GRANT SELECT ON students TO user1; ``` 可以授予的权限包括 `SELECT`、`INSERT`、`UPDATE`、`DELETE` 等,还可以授予对数据库对象的全部权限: ```sql GRANT ALL PRIVILEGES ON students TO user1; ``` ##### 撤销权限(REVOKE) REVOKE 语句用于撤销用户或角色已有的权限。例如,撤销用户 `user1` 对 `students` 表的 `SELECT` 权限: ```sql REVOKE SELECT ON students FROM user1; ``` #### 事务控制 虽然事务控制也可以通过其他语句实现,但 DCL 中也包含了一些与事务相关的操作。 ##### 提交事务(COMMIT) COMMIT 语句用于将当前事务中的所有更改永久保存到数据库中。例如: ```sql BEGIN; -- 执行一系列 DML 操作 INSERT INTO students (student_id, name, age) VALUES (2, 'Jane Smith', 22); UPDATE students SET age = 23 WHERE student_id = 2; COMMIT; ``` 在上述代码中,`BEGIN` 开始一个事务,执行一系列 DML 操作后,使用 `COMMIT` 语句将这些更改永久保存。 ##### 回滚事务(ROLLBACK) ROLLBACK 语句用于撤销当前事务中所有未提交的更改。例如: ```sql BEGIN; -- 执行一系列 DML 操作 INSERT INTO students (student_id, name, age) VALUES (3, 'Bob Johnson', 24); UPDATE students SET age = 25 WHERE student_id = 3; -- 发现错误,回滚事务 ROLLBACK; ``` 执行 `ROLLBACK` 后,上述 DML 操作的更改将被撤销。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值