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 删除以后, 自增值仍然会继续累加。

相关推荐
IvorySQL19 分钟前
济南站活动回顾|IvorySQL中的Oracle XML函数使用示例及技术实现原理
xml·数据库·sql·postgresql·oracle·开源
Data 31744 分钟前
Hive数仓操作(十)
大数据·数据库·数据仓库·hive·hadoop
ON.LIN44 分钟前
Hadoop大数据入门——Hive-SQL语法大全
大数据·数据库·hive·hadoop·分布式·sql
Elastic 中国社区官方博客1 小时前
Elasticsearch 开放推理 API 增加了对 Google AI Studio 的支持
大数据·数据库·人工智能·elasticsearch·搜索引擎
董乐,快乐的乐!1 小时前
Study-Oracle-11-ORALCE19C-ADG集群搭建
数据库·oracle
青云交2 小时前
大数据新视界 --大数据大厂之 Kafka 性能优化的进阶之道:应对海量数据的高效传输
大数据·数据库·人工智能·性能优化·kafka·数据压缩·分区策略·磁盘 i/o
Sarapines Programmer2 小时前
【Sqlite】sqlite内部函数sqlite3_value_text特性
数据库·sqlite·数据转换·科学计数法
打码人的日常分享2 小时前
企业人力资源管理,人事档案管理,绩效考核,五险一金,招聘培训,薪酬管理一体化管理系统(源码)
java·数据库·python·需求分析·规格说明书
unix2linux2 小时前
Parade Series - SHA256
linux·python·mysql·shell
好好学习的人2 小时前
SQL第12课——联结表
数据库·sql