MySQL中DML操作(九)

MySQL中DML操作(九)

DML语言是操作数据的语言

一、添加数据(INSERT)

1.1 选择插入

INSERT INTO 表名(列名 1 ,列名 2 ,列名

3.....) VALUES(值 1 ,值 2 ,值 3......);

1.2 完成插入

INSERT INTO 表名 VALUES(值 1 ,值 2 ,值

3......);

​ 如果主键是自动增长,需要使用 default 或者 null 或者 0 占位。

二、默认值处理(DEFAULT)

在 MySQL 中可以使用 DEFAULT 为列设定一个默认值。如果在插入数据时并未指定该列的值,那么 MySQL 会将默认值添加到该列中。

2.1 创建表时指定列的默认值

CREATE TABLE 表名(列名 类型 default 默认

值,......);

2.2 修改表添加新列并指定默认值

ALTER TABLE 表名 ADD COLUMN 列名 类型 DEFAULT

默认值;

2.3 插入数据时的默认值处理

如果在插入数据时并未指定该列的值,那么MySQL 会将默认值添加到该列中。如果是 完全项插入需要使用 default 占位。

三、更新数据(UPDATE)

UPDATE 表名 SET 列名=值,列名=值 WHERE 条件;

更新语句中一定要给定更新条件,否则表中的所有数据都会被更新。

四、删除数据(DELETE)

DELETE FROM 表名 WHERE 条件;

在DELETE语句中,如果没有给定删除条件则会删除表中的所有数据。

五、TRUNCATE清空表

TRUNCATE TABLE 表名;

六、清空表时DELETE TRUNCATE 区别

  1. truncate 是整体删除(速度较快), delete 是逐条删除(速度较慢);

  2. truncate 不写服务器 log,delete 写服务器 log,也就是 truncate 效率比 delete 高的原因;

  3. truncate 是会重置自增值,相当于自增列会被置为初始值,又重新从 1 开始记录,而 不是接着原来的值。而 delete 删除以后, 自增值仍然会继续累加。

相关推荐
_ku_ku_19 分钟前
数据库系统原理 · 数据库应用开发 · 自学总结
数据库
长谷深风1111 小时前
索引提速秘籍【个人八股】
mysql·b+树·索引·索引设计原则·存储引擎优化·索引维护成本·字段选择策略
No8g攻城狮1 小时前
【人大金仓】wsl2+ubuntu22.04安装人大金仓数据库V9
java·数据库·spring boot·非关系型数据库
山峰哥1 小时前
SQL慢查询调优实战:从全表扫描到索引覆盖的完整复盘
前端·数据库·sql·性能优化
Irene19911 小时前
在 WSL 中下载安装 MySQL,连接到 SQLyog(MySQL 安装在 WSL vs Windows 本地对比)
mysql·wsl
代码中介商2 小时前
Redis入门:5大数据类型全解析
数据库·redis·缓存
渣渣盟2 小时前
数据库设计范式详解(纯小白版)
数据库·oracle·软考·数据库工程师
夜雪闻竹3 小时前
Cursor 对话导入:解析 SQLite 里的宝藏
数据库·sqlite·ai编程
hhb_6184 小时前
PL/SQL核心技术难点梳理与实战应用案例解析
数据库·sql
m0_470857644 小时前
PHP怎么实现工厂模式_Factory模式编写指南【指南】
jvm·数据库·python