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

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条件的记录。


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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值