前言
对于数据库来说,分几个等级,一个是容器级别的(库、表等),一个是数据级别的,今天所要讨论的就是数据的增、删、改,对于数据的查找,我们已经做了较为详细的分析。
1、增(插入数据)INSERT
使用INSERT语句向表中插入数据。
1.1 VALUES的方式添加
- 为表的所有字段按默认顺序插入数据
- 为表的指定字段插入数据,就是在INSERT语句中只向部分字段中插入值,而其他字段的值为表定义时的默认值。在 INSERT 子句中随意列出列名,但是一旦列出,VALUES中要插入的value1,…valuen需要与column1,…columnn列一一对应。如果类型不同,将无法插入,并且MySQL会产生错误。
1.2 与SELECT语句相配合
在insert语句中加入子查询, 将SELECT语句查询结果插入到表中,可以快速的实现一个表或多个表向一个表中插入多行
列多少不一致添加不成功,列参数不一致,添加不成功。
INSERT INTO 目标表名
(tar_column1 [, tar_column2, …, tar_columnn])
SELECT
(src_column1 [, src_column2, …, src_columnn])
FROM 源表名
[WHERE condition]
--子查询中的值列表应与 INSERT 子句中的列名对应。
2、删 DELETE
table_name指定要执行删除操作的表;“[WHERE ]”为可选参数,指定删除条件,如果没有WHERE子句,DELETE语句将删除表中的所有记录。
DELETE FROM table_name [WHERE <condition>];
注意如果删除的列是有外键约束的,可能会产生数据完整性错误
3、改 UPDATE
可以一次更新多条数据。
如果需要回滚数据,需要保证在DML前,进行设置:SET AUTOCOMMIT = FALSE;
UPDATE 表名
SET 字段名=?
[WHERE condition]
注意如果修改的列是有外键约束的,可能会产生数据完整性错误
4、计算列
简单来说就是某一列的值是通过别的列计算得来的。例如,a列值为1、b列值为2,c列
不需要手动插入,定义a+b的结果为c的值,那么c就是计算列,是通过别的列计算得来的
设定方式
CREATE TABLE 和 ALTER TABLE 中都支持增加计算列
CREATE TABLE tb1(
id INT,
a INT,
b INT,
c INT GENERATED ALWAYS AS (a + b) VIRTUAL
);