数据库初探(七)-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条件的记录。


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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354