数据处理之增删改

发布时间 2023-05-28 15:45:27作者: 爱笑的小胡纸

1. 插入数据

1.1 方式1:VALUES的方式添加

使用这种语法一次只能向表中插入一条数据
情况1:为表的所有字段按默认顺序插入数据

INSERT INTO 表名 VALUES (value1,value2,....);
  • 举例:
mysql> INSERT INTO emp VALUES(1, 'Tom', '2023-5-19', 3400);
Query OK, 1 row affected (0.00 sec)

mysql> INSERT INTO emp VALUES('Jerry', 2,  '2023-5-19', 3400);
ERROR 1366 (HY000): Incorrect integer value: 'Jerry' for column 'id' at row 1
mysql> 
  • 值列表中需要为表的每一个字段指定值,并且值的顺序必须和数据表中字段定义时的顺序相同

情况2:指明要添加的字段 (推荐)

INSERT INTO 表名(column1 [, column2, …, columnn]) 
VALUES (value1 [,value2, …, valuen]);
  • 为表的指定字段插入数据,就是在INSERT语句中只向部分字段中插入值,而其他字段的值为表定义时的默认值
  • 在 INSERT 子句中随意列出列名,但是一旦列出,VALUES中要插入的value1,....valuen需要与column1,...columnn列一一对应。如果类型不同,将无法插入,并且MySQL会产生错误
mysql> INSERT INTO emp(id, hire_date, salary, name)
    -> VALUES(2, '2023-5-20', 4000, 'Jerry');
Query OK, 1 row affected (0.01 sec)
# 说明:没有进行赋值的hire_date 的值为 null
mysql> INSERT INTO emp(id, salary, name)
    -> VALUES(3, 4500, 'Ahk');
Query OK, 1 row affected (0.00 sec)

mysql> 

情况3:同时插入多条记录

  • INSERT语句可以同时向数据表中插入多条记录,插入时指定多个值列表,每个值列表之间用逗号分隔开,基本语法格式如下: