Maison base de données tutoriel mysql MySQL如何快速插入大量数据_MySQL

MySQL如何快速插入大量数据_MySQL

Jun 01, 2016 pm 01:36 PM
如何 数据库

bitsCN.com

MySQL如何快速插入大量数据

 

这几天尝试了使用不同的存储引擎大量插入MySQL表数据,主要试验了MyISAM存储引擎和InnoDB。
下面是实验过程:    

一、InnoDB存储引擎。

创建数据库和表

Sql代码  

CREATE DATABASE ecommerce;  

CREATE TABLE employees (       

    id INT NOT NULL,       

    fname VARCHAR(30),       

    lname VARCHAR(30),    

    birth TIMESTAMP,         

    hired DATE NOT NULL DEFAULT '1970-01-01',       

    separated DATE NOT NULL DEFAULT '9999-12-31',       

    job_code INT NOT NULL,       

    store_id INT NOT NULL      

)   

         

partition BY RANGE (store_id) (       

    partition p0 VALUES LESS THAN (10000),       

    partition p1 VALUES LESS THAN (50000),       

    partition p2 VALUES LESS THAN (100000),       

    partition p3 VALUES LESS THAN (150000),  

    Partition p4 VALUES LESS THAN MAXVALUE       

);  

     

创建存储过程

Sql代码  

use ecommerce;  

CREATE PROCEDURE BatchInsert(IN init INT, IN loop_time INT)  

BEGIN  

    DECLARE Var INT;  

    DECLARE ID INT;  

    SET Var = 0;  

    SET ID = init;  

        WHILE Var

        insert into employees(id,fname,lname,birth,hired,separated,job_code,store_id) values(ID,CONCAT('chen',ID),CONCAT('haixiang',ID),Now(),Now(),Now(),1,ID);  

        SET ID = ID + 1;  

        SET Var = Var + 1;  

        END WHILE;  

END;  

 

调用存储过程插入数据

Sql代码  

CALL BatchInsert(30036,200000)  

用时:3h 37min 8sec

二、MyISAM存储引擎

创建表

Sql代码  

use ecommerce;  

CREATE TABLE ecommerce.customer (  

   id INT NOT NULL,  

   email VARCHAR(64) NOT NULL,  

   name VARCHAR(32) NOT NULL,  

   password VARCHAR(32) NOT NULL,  

   phone VARCHAR(13),  

   birth DATE,  

   sex INT(1),  

   avatar BLOB,  

   address VARCHAR(64),  

   regtime DATETIME,  

   lastip VARCHAR(15),  

   modifytime TIMESTAMP NOT NULL,  

  PRIMARY KEY (id)  

)ENGINE = MyISAM ROW_FORMAT = DEFAULT  

partition BY RANGE (id) (       

    partition p0 VALUES LESS THAN (100000),       

    partition p1 VALUES LESS THAN (500000),       

    partition p2 VALUES LESS THAN (1000000),       

    partition p3 VALUES LESS THAN (1500000),  

    partition p4 VALUES LESS THAN (2000000),  

    Partition p5 VALUES LESS THAN MAXVALUE       

);  

 

创建存储过程

Sql代码  

use ecommerce;  

DROP PROCEDURE IF EXISTS ecommerce.BatchInsertCustomer;  

CREATE PROCEDURE BatchInsertCustomer(IN start INT,IN loop_time INT)  

BEGIN  

    DECLARE Var INT;  

    DECLARE ID INT;  

    SET Var = 0;  

    SET ID= start;  

        WHILE Var

        DO  

        insert into customer(ID,email,name,password,phone,birth,sex,avatar,address,regtime,lastip,modifytime)   

        values(ID,CONCAT(ID,'@sina.com'),CONCAT('name_',rand(ID)*10000 mod 200),123456,13800000000,adddate('1995-01-01',(rand(ID)*36520) mod 3652),Var%2,'http://t3.baidu.com/it/u=2267714161,58787848&fm=52&gp=0.jpg','北京市海淀区',adddate('1995-01-01',(rand(ID)*36520) mod 3652),'8.8.8.8',adddate('1995-01-01',(rand(ID)
*36520) mod 3652));  

        SET Var = Var + 1;  

        SET ID= ID + 1;  

        END WHILE;  

END;  

 

调用存储过程插入数据

Sql代码  

ALTER  TABLE  customer  DISABLE  KEYS;   

CALL BatchInsertCustomer(1,2000000);  

ALTER  TABLE  customer  ENABLE  KEYS;  

 

用时:8min 50sec

通过以上对比发现对于插入大量数据时可以使用MyISAM存储引擎,如果再需要修改MySQL存储
引擎可以使用命令:

Sql代码  

ALTER TABLE t ENGINE = MYISAM;  

bitsCN.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment le langage Go implémente-t-il les opérations d'ajout, de suppression, de modification et de requête de la base de données ? Comment le langage Go implémente-t-il les opérations d'ajout, de suppression, de modification et de requête de la base de données ? Mar 27, 2024 pm 09:39 PM

Comment le langage Go implémente-t-il les opérations d'ajout, de suppression, de modification et de requête de la base de données ?

Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP Jun 04, 2024 pm 01:42 PM

Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP

Comparaison des similitudes et des différences entre MySQL et PL/SQL Comparaison des similitudes et des différences entre MySQL et PL/SQL Mar 16, 2024 am 11:15 AM

Comparaison des similitudes et des différences entre MySQL et PL/SQL

Comment Hibernate implémente-t-il le mappage polymorphe ? Comment Hibernate implémente-t-il le mappage polymorphe ? Apr 17, 2024 pm 12:09 PM

Comment Hibernate implémente-t-il le mappage polymorphe ?

iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées Jul 18, 2024 am 05:48 AM

iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées

Analyse des principes de base du système de gestion de base de données MySQL Analyse des principes de base du système de gestion de base de données MySQL Mar 25, 2024 pm 12:42 PM

Analyse des principes de base du système de gestion de base de données MySQL

Une analyse approfondie de la façon dont HTML lit la base de données Une analyse approfondie de la façon dont HTML lit la base de données Apr 09, 2024 pm 12:36 PM

Une analyse approfondie de la façon dont HTML lit la base de données

Conseils et pratiques pour gérer les caractères chinois tronqués dans les bases de données avec PHP Conseils et pratiques pour gérer les caractères chinois tronqués dans les bases de données avec PHP Mar 27, 2024 pm 05:21 PM

Conseils et pratiques pour gérer les caractères chinois tronqués dans les bases de données avec PHP

See all articles