第三章 添加数据

添加数据

通常情况下,向数据表中添加的新记录应该包含表的所有字段,即为该表中的所有字段添加数据,为表中所有字段添加数据的INSERT语句有两种:

1.NSERT语句中指定字段名
复制代码
INSERT INTO 表名(字段名) VALUES(值);
INSERT INTO 表名(字段名1,字段名2,……) VALUES(值1,值2,……);

注意:必须列出表所有字段的名称,每个值的顺序、类型必须与对应的字段相匹配。

2.INSERT语句中不指定字段名
复制代码
INSERT INTO 表名 VALUES(值1,值2,……)

注意:由于INSERT语句中没有指定字段名,添加的值的顺序必须和字段在表中定义的顺序相同。

MySQL中,也可以在INSERT语句中只向部分字段中添加值。

3.INSERT语句中只向部分字段中添加值
复制代码
INSERT INTO 表名 SET 字段名1=值1[,字段名2=值2,……]

注意:如果在SET关键字后面指定了多个"字段名=值"对,每对之间使用逗号分隔,最后一个"字段名=值"对之后不需要逗号。

有时,也需要一次向表中添加多条记录,所以在MySQL中,也提供了如何使用一条INSERT语句同时添加多条记录的功能。

4.一条INSERT语句同时添加多条记录
复制代码
INSERT INTO 表名[(字段名1,字段名2,……) ]
VALUES(值1,值2,……),(值1,值2,……),
     … …
(值1,值2,……);
示例
复制代码
#为字段name添加数据
mysql> insert into classes(name) values('1班');
Query OK, 1 row affected (0.13 sec)
​
#同时添加多条记录
mysql> insert into classes(name) values('2班'),('3班'),('4班');
Query OK, 3 rows affected (0.10 sec)
Records: 3  Duplicates: 0  Warnings: 0

#添加一条数据到student表中
#因为主键是自增长的,不需要我们手动设置
insert into students(name,age,gender,height,enrollment_time,allowance,cid)
values('小明',18,'男',170,'1990-02-02',50,null);

#新增记录时,可以指定要设置的列,但是需要考虑非空列也必须设置值
insert into students(name,age,gender)
values('小汪',18,'男');

#为student表添加多条数据
insert into students(name,age,gender,height,enrollment_time,allowance,cid) values('张三',18,'男',180,'1980-12-17',30,1);
insert into students(name,age,gender,height,enrollment_time,allowance,cid) values('李四',20,'女',150,'1981-02-20',50,2);
insert into students(name,age,gender,height,enrollment_time,allowance,cid) values('王五',38,'男',170,'1985-02-22',60,3);
insert into students(name,age,gender,height,enrollment_time,allowance,cid) values('赵六',28,'女',155,'1983-04-02',50,1);
insert into students(name,age,gender,height,enrollment_time,allowance,cid) values('孙七',29,'男',168,'1981-09-28',50,2);
insert into students(name,age,gender,height,enrollment_time,allowance,cid) values('张雷',30,'男',171,'1984-05-01',50,3);

#为student表批量插入数据(同时添加多条数据)
insert into students(name,age,gender,height,enrollment_time,allowance,cid)
values
  ('小王',18,'男',170,'1990-02-02',50,null)
 ,('小张',18,'男',170,'1990-02-02',50,null)
 ,('小李',18,'男',170,'1990-02-02',50,null)
 ,('小六',18,'男',170,'1990-02-02',50,null);

​
相关推荐
Omics Pro8 分钟前
「自兹以往」动物肠道微生物组
数据库·人工智能·机器学习·语言模型·自然语言处理
zzz_236816 分钟前
【Redis】分布式锁完整演进
数据库·redis·分布式
mN9B2uk1737 分钟前
数据库的约束简介
java·数据库·sql
计算机安禾38 分钟前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
Henry-SAP39 分钟前
SAP(ERP) BOM变更实时同步MRP方案
数据库·云原生
AI人工智能+电脑小能手41 分钟前
【大白话说Java面试题 第99题】【Mysql篇】第29题:如何选择合适的分布式主键方案?
java·数据库·分布式·mysql·面试
倔强的石头_2 小时前
kingbase备份与恢复实战(七)—— 恢复演练与验收:从“能恢复”到“可交付预案”
数据库
满昕欢喜2 小时前
第2章 SQL Server 2019服务器管理
数据库·sqlserver
giaz14n9X2 小时前
Redis 分布式锁进阶第五十一篇
数据库·redis·分布式
念越2 小时前
【数据库系统概论期末复习】第四章 数据库安全性重点与常考题整理
数据库·数据库系统概论