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子句,那么表中所有记录的col1
和col2
字段的值都会被修改为value1
和value2
。
例如,我们有一个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
条件的记录。
以上就是数据操作语言的基本内容。