当前位置:网站首页 > 编程语言 > 正文

增删改查是什么功能(增删改查是ddl还是dml)



前言: 

在上篇文章中,主要为大家介绍的是DDL语句的用法,可能细心的同学已经发现了。本篇文章将主要聚焦于DML语句,为大家讲解表数据相关操作

这里说明下DDL与DML语句的分类,可能有的同学还不太清楚。 DDL(Data Definition Language):数据定义语言,用于创建、删除、修改、库或表结构,对数据库或表的结构操作。常见的有create,alter,drop等。 DML(Data Manipulation Language):数据操纵语言,主要对表记录进行更新(增、删、改)。常见的有insert,update,delete等。

1.插入数据

插入数据主要用到的是insert语法,官方文档同样给出很多选项:

 

有兴趣的同学可以咨询研究下上面的各个选项哦,下面我将分类给大家介绍几个常用的语法。

INSERT INTO ... VALUES (...) 

这可能是你写insert语句最常用的一种,标准用法为:

 

语法说明如下:

  •  :指定被操作的表名。
  •  :指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 INSERT<表名>VALUES(…) 即可。
  •  或 VALUE 子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。

INSERT ... SET ... 

insert ... set语句一次只能插入一条数据,可以向表中插入部分列的值,这种方式更为灵活。

 

INSERT INTO ... SELECT ... 

INSERT INTO…SELECT…FROM 语句用于快速地从一个或多个表中取出数据,并将这些数据作为行数据插入另一个表中。

SELECT 子句返回的是一个查询到的结果集,INSERT 语句将这个结果集插入指定表中,结果集中的每行数据的字段数、字段的数据类型都必须与被操作的表完全一致。

举个例子,假如test表和test_bak表结构完全一致,我们想把test表中的数据插入到test_bak表中,那么我们可以这么操作:

 

INSERT ... ON DUPLICATE KEY UPDATE 

如果要插入的新行违反主键(PRIMARY KEY)或UNIQUE约束,则MySQL会报错,此语法就是为了解决此错误。当数据库中存在某个记录时,执行这条语句会更新它,而不存在这条记录时,会插入它。

下面举个例子为大家演示下效果:

 

REPLACE INTO ... VALUES ... 

replace into 跟 insert 功能类似,不同点在于:replace into 首先尝试插入数据到表中, 1. 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。 2. 否则,直接插入新数据。

同样举个例子说明下:

 

2.更新数据

update语句用于更新表数据,官方推荐语法为:

 

同样的,这里只给大家介绍常用的单表更新语法:

 

语法说明如下:

  • :用于指定要更新的表名称。
  •  子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字 DEFAULT 表示列值。
  •  子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行。
  •  子句:可选项。用于限定表中的行被修改的次序。
  •  子句:可选项。用于限定被修改的行数。

3.删除数据

delete语句用于删除表数据,官方文档推荐语法:

 

使用 DELETE 语句从单个表中删除数据,语法格式为:

 

语法说明如下:

  • :指定要删除数据的表名。
  •  子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。
  •  子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。
  •  子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。

总结: 

本文主要介绍了三种DML语句的语法,看似简单,其实其中各种选项还是很复杂的,特别是insert语句,经常用到的选项就有很多。在这里也要提醒大家,执行update或delete语句时一定要小心,不使用where条件会更新或删除全部数据哦。

到此这篇增删改查是什么功能(增删改查是ddl还是dml)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 手机号被恶意发送短信验证码,怎么办(手机被恶意发送验证码可以报警吗)2025-02-18 14:45:07
  • 网页传输文件的网站(网页传输文件的网站叫什么)2025-02-18 14:45:07
  • py文件(py文件怎么打包成exe)2025-02-18 14:45:07
  • ubuntu20更新源(ubuntu更新源有什么用)2025-02-18 14:45:07
  • 批量删除文件第一行(删除文件的第一行)2025-02-18 14:45:07
  • 网上聊天网页(网上聊天网页没有本地记录)2025-02-18 14:45:07
  • 跨区域物流(跨区域物流调研报告)2025-02-18 14:45:07
  • ubuntu安装qt命令(ubuntu如何安装qt)2025-02-18 14:45:07
  • boos源空白(bigboss源空白解决办法)2025-02-18 14:45:07
  • dvp试验报告(dvp试验计划表)2025-02-18 14:45:07
  • 全屏图片