SQL--DML

DML英文全称是Data Manipulation Language(数据操作语言),用来对数据库中表的数据记录进 行增、删、改操作。

添加数据(INSERT)

修改数据(UPDATE)

删除数据(DELETE)

添加数据

1). 给指定字段添加数据

sql 复制代码
INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...);

案例: 给employee表所有的字段添加数据 ;

sql 复制代码
insert into employee(id,workno,name,gender,age,idcard,entrydate)
values(1,'1','Itcast','男',10,'123456789012345678','2000-01-01');

插入数据完成之后,我们有两种方式,查询数据库的数据:

A. 方式一 在左侧的表名上双击,就可以查看这张表的数据。

B. 方式二 可以直接一条查询数据的SQL语句, 语句如下:

sql 复制代码
select * from employee;

案例: 给employee表所有的字段添加数据

执行如下SQL,添加的年龄字段值为-1。

sql 复制代码
insert into employee(id,workno,name,gender,age,idcard,entrydate)
values(1,'1','Itcast','男',-1,'123456789012345678','2000-01-01');

执行上述的SQL语句时,报错了,具体的错误信息如下:

因为 employee 表的age字段类型为 tinyint,而且还是无符号的 unsigned ,所以取值只能在 0-255 之间。

2). 给全部字段添加数据

sql 复制代码
INSERT INTO 表名 VALUES (值1, 值2, ...);

案例:插入数据到employee表,具体的SQL如下:

sql 复制代码
insert into employee values(2,'2','张无忌','男',18,'123456789012345670','2005-01-
01');

3). 批量添加数据

sql 复制代码
INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), (值
1, 值2, ...) ;
INSERT INTO 表名 VALUES (值1, 值2, ...), (值1, 值2, ...), (值1, 值2, ...) ;

案例:批量插入数据到employee表,具体的SQL如下:

sql 复制代码
insert into employee values(3,'3','韦一笑','男',38,'123456789012345670','2005-01-
01'),(4,'4','赵敏','女',18,'123456789012345670','2005-01-01');

注意事项:

• 插入数据时,指定的字段顺序需要与值的顺序是一一对应的。

• 字符串和日期型数据应该包含在引号中。

• 插入的数据大小,应该在字段的规定范围内。

修改数据

修改数据的具体语法为:

sql 复制代码
UPDATE 表名 SET 字段名1 = 值1 , 字段名2 = 值2 , .... [ WHERE 条件 ] ;

案例:

A. 修改id为1的数据,将name修改为sakura

sql 复制代码
update employee set name = 'sakura' where id = 1;

B. 修改id为1的数据, 将name修改为小昭, gender修改为 女

sql 复制代码
update employee set name = '小昭' , gender = '女' where id = 1;

C. 将所有的员工入职日期修改为 2008-01-01

sql 复制代码
update employee set entrydate = '2008-01-01';

注意事项:

修改语句的条件可以有,也可以没有,如果没有条件,则会修改整张表的所有数据。

删除数据

删除数据的具体语法为:
sql 复制代码
 DELETE FROM 表名 [ WHERE 条件 ] ;

案例:

A. 删除gender为女的员工

sql 复制代码
delete from employee where gender = '女';

B. 删除所有员工

sql 复制代码
delete from employee;

注意事项:

• DELETE 语句的条件可以有,也可以没有,如果没有条件,则会删除整张表的所有数 据。 • DELETE 语句不能删除某一个字段的值(可以使用UPDATE,将该字段值置为NULL即 可)。 • 当进行删除全部数据操作时,datagrip会提示我们,询问是否确认删除,我们直接点击 Execute即可。

相关推荐
刘 大 望2 分钟前
数据库-联合查询(内连接外连接),子查询,合并查询
java·数据库·sql·mysql
从零开始学习人工智能30 分钟前
Doris 数据库深度解析:架构、原理与实战应用
数据库·架构
LiRuiJie1 小时前
深入剖析MySQL锁机制,多事务并发场景锁竞争
数据库·mysql
2501_915374351 小时前
Faiss向量数据库全面解析:从原理到实战
数据库·faiss
睡觉待开机1 小时前
0. MySQL在Centos 7环境安装
数据库·mysql·centos
2501_915374351 小时前
Faiss vs Milvus 深度对比:向量数据库技术选型指南
数据库·milvus·faiss
傻啦嘿哟2 小时前
Python 数据分析与可视化实战:从数据清洗到图表呈现
大数据·数据库·人工智能
cookqq3 小时前
mongodb源码分析session异步接受asyncSourceMessage()客户端流变Message对象
数据库·sql·mongodb·nosql
呼拉拉呼拉3 小时前
Redis故障转移
数据库·redis·缓存·高可用架构
什么都想学的阿超3 小时前
【Redis系列 04】Redis高可用架构实战:主从复制与哨兵模式从零到生产
数据库·redis·架构