广告
返回顶部
首页 > 资讯 > 数据库 >MySQL实现数据插入操作的示例详解
  • 475
分享到

MySQL实现数据插入操作的示例详解

MySQL数据插入操作MySQL数据插入MySQL数据 2023-02-21 16:02:09 475人浏览 安东尼
摘要

目录一、方法分类二、具体方法三、实例(1)常规插入(2)从另一个表导入(3)插入时数据重复四、注意事项(1)不写字段名,需要填充自增ID(2)按字段名填充,可以不录入id其余注意事项使用Mysql插入数据时,可以根据需求

使用Mysql插入数据时,可以根据需求场景选择合适的插入语句,例如当数据重复时如何插入数据,如何从另一个表导入数据,如何批量插入数据等场景。本文通过给出每个使用场景下的实例来说明数据插入的实现过程和方法。

一、方法分类

MySQL实现数据插入操作的示例详解

二、具体方法

使用场景作用语句注意
常规插入忽略字段名insert into 表名 values (值1, 值2,...,值n)默认value中的值依次填充所有字,如果出现唯一性冲突,就会抛出异常
按照字段插入insert into 表名(字段1, 字段2,...,字段n) values (值1, 值2,...,值n)字段和值一一对应
一次性插入多条数据insert into 表名(字段1, 字段2,...,字段n) values (值a1, 值a2,...,值an),(值b1, 值b2,...,值bn)多行之间用逗号隔开,不需要再次写insert into语句
从另一个表导入导出A表的某些数据插入到B表insert into 表名B(字段B1, 字段B2,...,字段Bn) select 字段A1, 字段A2,...,字段An from 表名A where [执行条件]字段A和B可以字段名称不一样,但是数据类型必须一致
插入时数据重复如果记录存在报错insert into 表名(字段1, 字段2,...,字段n) values (值1, 值2,...,值n)如果插入的数据记录存在,报错并捕获异常,不存在则直接新增记录
如果记录存在不插入记录insert ignore into 表名(字段1, 字段2,...,字段n) values (值1, 值2,...,值n)如果插入的数据记录存在就保存旧记录忽略新记录,不存在则直接新增记录
不论记录是否存在都要插入记录replace 表名(字段1, 字段2,...,字段n) values (值1, 值2,...,值n)如果插入的数据记录存在就先删除再更新,不存在则直接新增记录
如果记录存在更新指定字段insert into … on duplicate key update如果插入的数据记录存在就更新指定字段,不存在则直接新增记录

三、实例

students 表 (id表示主键,name是姓名,score是平均成绩)

idnamescore
1李明67

(1)常规插入

忽略字段名

执行后结果

idnamescore
1李明67
2张三74

按照字段插入

insert into 
	students(name) 
values('孙华');

执行后结果

idnamescore
1李明67
2张三74
3孙华

一次性插入多条数据

insert into 
	students(name, score) 
values('刘平', '56'),('周雨', '90');

执行后结果

idnamescore
1李明67
2张三74
3孙华
4刘平56
5周雨90

(2)从另一个表导入

students 表 (id表示主键,name是姓名,score是平均成绩)

iduser_namemobile_phone_number
1马化腾13800000000
2任正非13800000011
3马云13800000022

导出users表的某些数据插入到students表

insert into 
	students(name,score) 
select 
	user_name,
	mobile_phone_number 
from users where id <> 3;

执行结果

idnamescore
1李明67
2张三74
3孙华
4刘平56
5周雨90
6马化腾13800000000
7马云13800000022

注意:只要对应字段的类型一样,字段不一样也可以导入数据,不会冲突。

(3)插入时数据重复

如果记录存在报错

insert into 
	students 
values(1, '张三', '74');

执行结果: 报错

Duplicate entry '1' for key 'PRIMARY'

如果记录存在不插入记录

insert ignore into 
	students(id,name,score) 
values(1, '张三', '74');

执行结果:不插入不报错

Affected rows:0

idnamescore
1李明67
2张三74
3孙华
4刘平56
5周雨90
6马化腾13800000000
7马云13800000022

不论记录是否存在都要插入记录

replace 
	students
values(1, '张三', '74');

执行结果

idnamescore
1张三74
2张三74
3孙华
4刘平56
5周雨90
6马化腾13800000000
7马云13800000022

如果记录存在更新指定字段

insert into 
	students(id)
values(1) on duplicate key 
update 
	name = '李明',
	score = '67';

执行结果

idnamescore
1李明67
2张三74
3孙华
4刘平56
5周雨90
6马化腾13800000000
7马云13800000022

创建 students 表的代码

-- ----------------------------
-- Table structure for students
-- ----------------------------
DROP TABLE IF EXISTS `students`;
CREATE TABLE `students`  (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '学生id',
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '姓名',
  `score` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '成绩',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of students
-- ----------------------------
INSERT INTO `students` VALUES (1, '李明', '67');

创建 users 表的代码

-- ----------------------------
-- Table structure for students
-- ----------------------------
DROP TABLE IF EXISTS `users`;
CREATE TABLE `users`  (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '用户id',
  `user_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '用户名',
  `mobile_phone_number` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '手机号码',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of students
-- ----------------------------
INSERT INTO `users` VALUES (1, '马化腾', '13800000000');
INSERT INTO `users` VALUES (2, '任正非', '13800000011');
INSERT INTO `users` VALUES (3, '马云', '13800000022');

四、注意事项

(1)不写字段名,需要填充自增ID

[使用]:0或者null或者default,自增id默认从1开始。

[使用]:或者没有在自增id中出现的(不重复)数(例如-1,-2),浮点型数据例如3.4,最后显示3,会进行四舍五入。即使定义了int类型,输入‘3’或者浮点型,都会强制转化为int类型,但是输入'a'会报错。具体细节可以看源码

问题:第一个字段id为什么可以写null?如果建表的时候写了id为自增id,而写0或者null或者default或者没有在自增id中出现的(不重复)数(例如-1,-2),系统都会自动填充id。如果建表的时候没有写明是自增id,那么主键一定是不能为空的,这个时候写null就会报错。

(2)按字段名填充,可以不录入id

[注意]:字段要与值一一对应。

其余注意事项

  • 字段名可以省略,默认所有列;
  • 录入值的类型和字段的类型要一致或兼容;
  • 字段和值的个数必须一致。不能出现一行记录5个值,另外一行6个值的情况;
  • 如果写了字段,即使是空值也不能空着,用null代替;

到此这篇关于mysql实现数据插入操作的示例详解的文章就介绍到这了,更多相关Mysql数据插入内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL实现数据插入操作的示例详解

本文链接: https://www.lsjlt.com/news/196987.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL实现数据插入操作的示例详解
    目录一、方法分类二、具体方法三、实例(1)常规插入(2)从另一个表导入(3)插入时数据重复四、注意事项(1)不写字段名,需要填充自增ID(2)按字段名填充,可以不录入id其余注意事项使用mysql插入数据时,可以根据需求...
    99+
    2023-02-21
    MySQL数据插入操作 MySQL数据插入 MySQL数据
  • 利用MySqlBulkLoader实现批量插入数据的示例详解
    目录介绍1.将List转化为DataTable 2.将DataTable转换为标准的CSV文件 3.CSV文件导入数据到数据库4.使用MySqlBulkLoade...
    99+
    2022-11-13
  • MySQL数据操作管理示例详解
    目录一、查看表和查看表的定义二、删除表三、创建表四、表类型五、修改表六、完整性1、数据完整性2、使用约束实现数据完整性3、在数据表上添加约束4、删除约束七、添加数据八、修改数据九、删除数据十、SQL语句中的运算符算数运算...
    99+
    2022-09-23
  • MySQL怎么实现数据插入操作
    今天小编给大家分享一下MySQL怎么实现数据插入操作的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、方法分类二、具体方法使...
    99+
    2023-07-05
  • node操作mysql数据库实例详解
    本文实例讲述了node操作mysql数据库的方法。分享给大家供大家参考,具体如下: 1、建立数据库连接:createConnection(Object)方法 该方法接受一个对象作为参数,该对象有四个常用的属...
    99+
    2022-06-04
    详解 实例 操作
  • MySQL实现数据更新的示例详解
    目录一、方法分类二、具体用法(1)根据条件更新值(2)按照不同条件(批量)更新不同值三、实例(1)根据条件更新值(2)按照不同条件更新不同值一般在更新时会遇到以下场景: 1.所有字段全部更新; 2.根据条件更新字段中的某...
    99+
    2023-02-08
    MySQL数据更新操作 MySQL数据更新 MySQL更新
  • 用代码来示例MySql实现循环插入数据
    下文我给大家简单讲讲关于用代码来示例MySql实现循环插入数据,大家之前了解过相关类似主题内容吗?感兴趣的话就一起来看看这篇文章吧,相信看完用代码来示例MySql实现循环插入数据对大家多少有点帮助吧。&nb...
    99+
    2022-10-18
  • C#数据库操作的示例详解
    目录功能需求技术知识点准备工作实现步骤功能需求 1,利用随机数模拟产生每次考试成绩 2,将每次考试成绩存入到数据库 3,将每次考试成绩划分优、良、中、差、不及格五类,并作为查询条件,...
    99+
    2022-11-13
  • c#操作mongodb插入数据效率的示例分析
    这篇文章主要介绍了c#操作mongodb插入数据效率的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。mongodb的数据插入速度是其...
    99+
    2022-10-18
  • MySQL 表数据的导入导出操作示例
    本文实例讲述了MySQL 表数据的导入导出操作。分享给大家供大家参考,具体如下: 数据导出   使用 SELECT ...INTO OUTFILE ...命令来导出数据,具体语法如...
    99+
    2022-05-11
    MySQL 表数据 导入导出
  • mysql数据插入效率的示例分析
    这篇文章给大家分享的是有关mysql数据插入效率的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。做数据插入时,发现之前上班做哪些办公系统压根就没考虑过数据库性能这些,因为...
    99+
    2022-10-18
  • MYSQL数据库插入数据的基本操作
    下文主要给大家带来MYSQL数据库插入数据的基本操作,希望这些内容能够带给大家实际用处,这也是我编辑MYSQL数据库插入数据的基本操作这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。插入数据在建立一...
    99+
    2022-10-18
  • MySQL数据管理操作示例讲解
    目录外键DML语言添加 insert修改 update删除 delete外键 方式一:在创建表的时候,增加约束 删除有外键的表的时候,要先删除引用外键的表 物理外键:不建议使用,数据库级别的外键,不建议使用!(...
    99+
    2022-12-22
    MySQL数据管理 SQL数据管理
  • Java实现直接插入排序与折半插入排序的示例详解
    目录1.直接插入排序2. 折半插入排序1.直接插入排序 插入排序的基本思想: 主要分为两个区间, 无序区间和有序区间, 每次选择无序区间的第一个元素, 在有序区间内选择合适的位置进行...
    99+
    2022-11-13
  • Python3 操作 MySQL 插入一条数据并返回主键 id的实例
    Python 中貌似并没有直接返回插入数据 id 的操作(反正我是没找到),但是我们可以变通一下,找到最新插入的数据 #!/usr/bin/env python3 # -*- coding: UTF-8 -*- ...
    99+
    2022-05-27
    Python3 MySQL 插入数据 主键id
  • 用python实现操纵mysql数据库插入
    python操纵mysql数据库,向一个表中插入一条新的记录。 pycahrm提供一个很好的功能,在右边上面,可以连接数据库,并在里面手动操作数据库,连接步骤略过。 1.先看下表...
    99+
    2022-11-13
  • Pandas读存JSON数据操作示例详解
    目录引言读取json数据模拟数据参数oridentorident="split"orient="records"orient="in...
    99+
    2022-11-11
  • mysql插入多条数据的操作步骤
    这篇文章主要介绍mysql插入多条数据的操作步骤,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql插入多条数据的方法:1、登录mysql数据库;2、指定要插入多条数据的数据库;...
    99+
    2022-10-18
  • C++操作MySQL的实现示例
    Windows版本:       将libmysql.dll、libmysql.lib、mysql.h复制粘贴到项目文件中,或者项目设置里的包含目录和库目录添加路径...
    99+
    2022-05-20
    C++操作MySQL C++ MySQL
  • python实现MySQL 数据库表格创建 数据插入及获取插入ID操作教程
    目录创建表格检查表格是否存在主键插入数据到表格插入多行获取插入的ID创建表格 要在mysql中创建表格,请使用"CREATE TABLE"语句。 确保在创建连接时定义了数据库的名称。 示例创建一个名为...
    99+
    2023-11-11
    Python操作MySQL表格数据 Python操作MySQL
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作