msql学习三:DML语言
一、数据库意义
数据存储、数据管理
二、管理数据库数据的方法
- 通过sqlyog等管理工具管理数据库数据
- 通过DML语句管理数据库数据
DML语言:数据操作语言
- 用于操作数据库对象中的所包含的数据
- 包括:insert(添加数据语句)、update(更新数据语句)、delete(删除数据语句)
三、添加数据
insert命令
- 语法
insert into `表名` [(字段1,字段2,字段3,...)] values ('值1','值2','值3',...);
- 注意:
- 字段或值之间用英文逗号隔开 .
- ' 字段1,字段2...' 该部分可省略 , 但添加的值务必与表结构,数据列,顺序相对应,且数量一致 .
- 可同时插入多条数据 , values 后用英文逗号隔开 .
-- 语法 : INSERT INTO 表名[(字段1,字段2,字段3,...)] VALUES('值1','值2','值3')
INSERT INTO `grade` (gradename) VALUES ('大一');
-- 主键自增,那能否省略呢?
INSERT INTO `grade` VALUES ('大二'); -- 错误代码: 1136 Column count doesn't match value count at row 1
-- 结论:'字段1,字段2...'该部分可省略 , 但添加的值务必与表结构,数据列,顺序相对应,且数量一致.
-- 一次插入多条数据
INSERT INTO `grade` (gradename) VALUES ('大二'),('大三'),('大四');
四、修改数据
update命令
- 语法
update `表名` set 字段1='值1'[, 字段2='值2', ...] [where 条件];
- where条件子句
可以理解为有条件的从表中筛选数据
-- 修改年级信息
UPDATE `grade` SET gradename='高中' WHERE gradeid='1';
五、删除数据
delete命令
- 语法
delete from `表名` [where 条件];
注意:condition为筛选条件 , 如不指定则删除该表的所有列数据
-- 删除一条数据
DELETE FROM `grade` WHERE gradeid='1';
truncate
作用:用于完全清空表数据,但表结构,索引,约束等不变
- 语法
TRUNCATE [TABLE] `表名`;
-- 清空年级表
TRUNCATE `grade`;
注意:区别于delete命令
- 相同:都能删除数据,不删除表结构,但truncate速度更快
- 不同:使用TRUNCATE TABLE 重新设置AUTO_INCREMENT计数器、使用TRUNCATE TABLE不会对事务有影响 (事务后面会说)
举例
-- 创建一个测试表
CREATE TABLE `test` (
`id` INT(4) NOT NULL AUTO_INCREMENT,
`coll` VARCHAR(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=INNODB DEFAULT CHARSET=utf8
-- 插入几个测试数据
INSERT INTO test(coll) VALUES('row1'),('row2'),('row3');
-- 删除表数据(不带where条件的delete)
DELETE FROM test;
-- 结论:如不指定Where则删除该表的所有列数据,自增当前值依然从原来基础上进行,会记录日志.
-- 删除表数据(truncate)
TRUNCATE TABLE test;
-- 结论:truncate删除数据,自增当前值会恢复到初始值重新开始;不会记录日志.
-- 同样使用DELETE清空不同引擎的数据库表数据.重启数据库服务后
-- InnoDB : 自增列从初始值重新开始 (因为是存储在内存中,断电即失)
-- MyISAM : 自增列依然从上一个自增数据基础上开始 (存在文件中,不会丢失)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix