当前位置: 首页 > news >正文

SQL关键字三分钟入门:INSERT INTO —— 插入数据详解

在数据库操作中,除了查询数据,我们还需要经常添加新记录。例如:

  • 添加一个新用户;
  • 插入一条订单信息;
  • 批量导入一批商品数据。

这时候就需要使用 SQL 中非常基础但极其重要的关键字 —— INSERT INTO

它是向表中插入新行(记录)的核心方式,掌握它能让你轻松地为数据库“添砖加瓦”。


什么是 INSERT INTO?

INSERT INTO 是 SQL 中用于将新记录插入到表中的关键字语句。

你可以把它理解为:“我要往这张表里添加一行新数据”。


 基本语法

1. 插入完整的一行数据(指定所有字段)

INSERT INTO table_name (column1, column2, column3, ...)
VALUES (value1, value2, value3, ...);

2. 插入部分字段(只写需要的列)

INSERT INTO table_name (column1, column2)
VALUES (value1, value2);

⚠️ 注意:如果某些字段有默认值(如 DEFAULTAUTO_INCREMENT),不写也可以自动填充。

3. 插入多条记录(批量插入)

INSERT INTO table_name (column1, column2)
VALUES (value1_1, value1_2),(value2_1, value2_2),...
;

 示例讲解

假设我们有一个 users 表,结构如下:

idnameagegendercreated_at

其中:

  • id 是主键,自增;
  • created_at 默认值为当前时间。

 示例1:插入一条完整的记录

INSERT INTO users (name, age, gender, created_at)
VALUES ('张三', 20, '男', '2025-06-20');

 这会插入一个名为“张三”,年龄20,性别男,注册时间为今天的新用户。


 示例2:插入部分字段(省略自增和默认字段)

INSERT INTO users (name, age, gender)
VALUES ('李四', 22, '女');

 因为 id 是自增字段,created_at 有默认值,所以可以不写,系统会自动处理。


 示例3:批量插入多个用户

INSERT INTO users (name, age, gender)
VALUES('王五', 21, '男'),('赵六', 19, '女'),('孙七', 23, '男');

 一次插入三条记录,效率更高,适合批量导入数据。


 示例4:从其他表插入数据(INSERT INTO SELECT)

有时候你想把一张表的数据插入到另一张结构相似的表中:

INSERT INTO users_backup (name, age, gender)
SELECT name, age, gender FROM users WHERE age > 20;

 将 users 表中年龄大于20岁的用户插入到 users_backup 表中。


注意

操作技巧使用建议
主键或唯一约束冲突插入时若违反主键或唯一索引约束,会报错;可使用 INSERT IGNORE 或 ON CONFLICT(PostgreSQL)避免错误
自动增长字段如果是自增主键,可以不写该列,系统会自动分配
默认值若某列设置了默认值,可以不写,系统会自动填默认值
批量插入性能更优多条记录尽量用一个 INSERT 语句插入,而不是多次单条插入
数据类型匹配插入的值必须与字段类型匹配,否则可能报错或插入失败

 总结对比表

场景SQL 示例
插入单条记录INSERT INTO users (name, age) VALUES ('张三', 20);
插入部分字段INSERT INTO users (name, age) VALUES ('李四', 22);
批量插入多条记录INSERT INTO users (...) VALUES (...), (...), (...);
从其他表插入数据INSERT INTO target_table SELECT * FROM source_table;
http://www.lryc.cn/news/573407.html

相关文章:

  • Python实现MySQL建表语句转换成Clickhouse SQL
  • 【格与代数系统】偏序关系、偏序集与全序集
  • 2048小游戏C++板来啦!
  • 【Docker基础】Docker镜像管理:docker rmi、prune详解
  • 竞业限制协议能单独充当商业秘密的 “保护伞” 吗?
  • docker执行yum报错Could not resolve host: mirrorlist.centos.org
  • python web开发-Flask 蓝图(Blueprints)完全指南
  • 【Docker 08】Compose - 容器编排
  • C#测试调用EPPlus根据批注设置excel单元格内容
  • JavaEE初阶第三期:解锁多线程,从 “单车道” 到 “高速公路” 的编程升级(一)
  • 【开源项目】当大模型推理遇上“性能刺客”:LMCache 实测手记
  • linux安装minio并使用
  • 在Docker、KVM、K8S常见主要命令以及在Centos7.9中部署的关键步骤学习备存
  • XCUITest + Objective-C 详细示例
  • FastGPT:开启大模型应用新时代(4/6)
  • Springboot 配置 FastJson 替换 Jackson
  • Rabbitmq集成springboot,手动确认消息basicAck、basicNack、basicReject的使用
  • 在 MyBatis 的xml中,什么时候大于号和小于号可以不用转义
  • Axios 在 Vue3 项目中的使用:从安装到组件中的使用
  • 升级到 .NET 9 分步指南
  • “最浅”的陷阱:聊聊二叉树最小深度的递归坑点与解法哲学
  • 秋招Day14 - MySQL - SQL优化
  • c++11标准(5)——并发库(互斥锁)
  • 一、什么是生成式人工智能
  • 终端里的AI黑魔法:OpenCode深度体验与架构揭秘
  • Java ArrayList集合和HashSet集合详解
  • 【论文笔记】【强化微调】TinyLLaVA-Video-R1:小参数模型也能视频推理
  • 人人都是音乐家?腾讯开源音乐生成大模型SongGeneration
  • 旧物回收小程序开发:开启绿色生活新方式
  • Python列表常用操作方法