码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 使用java代码向mysql数据库插入100万条数据


    使用java代码向mysql数据库插入100万条数据

    使用springboot集成Mysql数据库,并使用java代码循环向msql数据库插入100万条数据,并测试插入时间

    目录结构

    • 使用java代码向mysql数据库插入100万条数据
      • 一、使用工具
      • 二、项目结构图
        • 创建springboot项目启动类
        • 创建插入数据类
      • 三、结论
      • 四、表结构与建表语句
        • 表结构
        • 建表语句
      • pom.xml与application.yml
        • pom.xml文件
        • 配置文件application.yml

    一、使用工具

    idea代码开发工具
    mysq5.7.38
    Navicat可视化工具

    二、项目结构图

    在这里插入图片描述

    创建springboot项目启动类

    MySpringBootApplication.java

    package com.xiaoa;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @SpringBootApplication
    public class MySpringBootApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(MySpringBootApplication.class);
        }
    
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    创建插入数据类

    MySchedulRunner.java,此类使用 JdbcTemplate 执行拼接的sql语句。

    package com.xiaoa.run;
    
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.boot.CommandLineRunner;
    import org.springframework.jdbc.core.JdbcTemplate;
    import org.springframework.stereotype.Component;
    
    @Component
    public class MySchedulRunner implements CommandLineRunner {
        private static final Logger LOGGER = LoggerFactory.getLogger(MySchedulRunner.class);
    
        @Autowired
        JdbcTemplate jdbcTemplate;
    
        @Override
        public void run(String... args) {
    
            /*
             *向数据库t_user表循环插入数据
             */
            String sql = "";
            long t1 = System.currentTimeMillis();
            int batchNum = 1000000;
            for (int i = 1; i <= batchNum; i++) {
                sql = "INSERT INTO t_user VALUES (" + i + ",'张三', 20, '男', '2019-01-01 00:00:01')";
                jdbcTemplate.execute(sql);
            }
            long t2 = System.currentTimeMillis();
            LOGGER.info("插入{}条数据,耗时{}秒", batchNum, (t2 - t1) / 1000);
    
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33

    三、结论

    使用Navicat查看插入的数据
    数据成功插入到myql数据库中!
    在这里插入图片描述

    经过测试此代码成功将100万条数据插入到了mysql数据库,耗时2116秒,约1000000/2116=472条/秒,速度比手工插入还是快很多的!

    四、表结构与建表语句

    表结构

    使用Navicat查看表结构
    在这里插入图片描述

    建表语句

    CREATE TABLE `t_user`  (
      `id` int(11) NOT NULL,
      `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL,
      `age` int(11) NULL DEFAULT NULL,
      `sex` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL,
      `createtime` datetime(0) NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP(0),
      PRIMARY KEY (`id`) USING BTREE
    ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_bin ROW_FORMAT = Dynamic;
    
    SET FOREIGN_KEY_CHECKS = 1;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    pom.xml与application.yml

    pom.xml文件

    
    
        4.0.0
    
        
            org.springframework.boot
            spring-boot-starter-parent
            2.0.4.RELEASE
        
    
        com.xiaoa
        springboot-mysql
        1.0-SNAPSHOT
        xiaoa-mysql
        springboot集成mysql
    
        
            8
            8
        
    
        
            
                org.springframework.boot
                spring-boot-starter-web
            
            
            
                mysql
                mysql-connector-java
                5.1.40
            
            
                org.springframework.boot
                spring-boot-starter-jdbc
            
    
        
    
        
            
                
                    org.springframework.boot
                    spring-boot-maven-plugin
                    
                    
                        
                            
                                repackage
                            
                        
                    
                
            
        
    
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60

    配置文件application.yml

    spring:
      #DB Configuration:
      datasource:
        driverClassName: com.mysql.jdbc.Driver
        url: jdbc:mysql://192.168.88.128:3306/canel?useUnicode=true&characterEncoding=utf8
        username: root
        password: 123456
    server:
      port: 8085
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    链接: 完整代码

  • 相关阅读:
    不会代码循环断言如何实现?只要6步!
    Mac上使用M1或M2芯片的设备安装Node.js时遇到一些问题,比如卡顿或性能问题
    CHATGPT----自然辩证法分析
    学习笔记:根号分治(优雅的暴力)
    [ROC-RK3568-PC] [Firefly-Android] 10min带你了解PWM的使用
    Java开发必须掌握的运维知识 (十)-- Docker集群自动化部署管理:Kubernetes快速入门
    代码随想录算法训练营第二十九天丨 回溯算法part06
    20221115 今天的世界发生了什么
    C#结合OpenCVSharp4使用直方图算法比较图片相似度
    计算机视觉与深度学习-图像分割-视觉识别任务01-语义分割-【北邮鲁鹏】
  • 原文地址:https://blog.csdn.net/niyite/article/details/127979967
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号