Mysql 学习(二):数据操作语言 -- DML (内含数据库)

DML语言:

数据操作语言:用于操作数据库对象所包含的数据。

  • Insert
  • update
  • delete

创建数据表 grade,用于演示接下来的操作:

USE school;
CREATE TABLE IF NOT EXISTS grade(
	`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '年级id',
	`gradename` VARCHAR(50) NOT NULL COMMENT '年级名称',
	PRIMARY KEY (`id`)
) ENGINE=INNODB CHARSET=utf8;

2.1 添加数据:

添加数据主要使用的时 INSERT 关键字:

-- 可以同时插入多条数据,每条数据之间用逗号分隔。
insert into 表名(字段1,字段2,.....) values (字段1,字段2.....);
-- 主键是自增的,表名后的字段属性不能省略,字段属性和插入的字段需要进行一一匹配
INSERT INTO `grade`(gradename) VALUES('高中'),('大一');

注意: 添加的值务必与表机构,数据列,顺序相对应,且数量一致。

2.2 更新数据:

更新数据主要使用的是 update 关键字:

-- update 表名 set 字段名 = 字段值 where 条件,当没有条件时所有的该列所有的值都会被修改
UPDATE `grade` SET gradename = '大二' WHERE id = '1';

where 字句: 有条件从表中筛选数据。

2.3 删除数据:

删除数据主要使用的是 delete 关键字:

-- 从 grade 表中删除 id 为 2 的记录
DELETE FROM `grade` WHERE id = '2';

-- 如果没有 where 字句则会删除 表中所有的数据
DELETE FROM `grade` ;

truncate命令:用于完全清空表数据,但表结构,索引,约束等不变。

TRUNCATE TABLE `grade`;

delete 与 truncate 之间的区别:

  • 相同 : 都能删除表中的数据, 但 truncate 速度更快。
  • 不同 :
    • 使用 truncate table 会重新设置 auto_increment 计数器(重新从 1 开始)。
    • 使用 truncate table 不会对事务产生影响。
-- 观察 id 的变化
INSERT INTO `grade`(gradename) VALUES('高中'),('大一'),('大二'),('大三');
DELETE FROM `grade` ;
SELECT * FROM grade;
INSERT INTO `grade`(gradename) VALUES('高中'),('大一'),('大二'),('大三');
SELECT * FROM grade;
TRUNCATE TABLE `grade`;
INSERT INTO `grade`(gradename) VALUES('高中'),('大一'),('大二'),('大三');
SELECT * FROM grade;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

潘小蓝

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值