mysql存儲中使用while批量插入數(shù)據(jù)(批量提交和單個提交的區(qū)別)
更新時間:2022年08月17日 11:09:05 作者:劉大大__
這篇文章主要介紹了mysql存儲中使用while批量插入數(shù)據(jù)(批量提交和單個提交的性能差異),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
批量提交
while 語句寫法:
? ? while '條件' do ? ? ? ? ? ? 循環(huán)體語句; ? ? end while;
完整寫法
drop procedure if exists test_insert; delimiter $$ create procedure test_insert(n int) ?? ?begin ?? ?declare v int default 0; ?? ?set AUTOCOMMIT = 0; ?? ?while v < n ?? ??? ?do ?? ??? ??? ??? ?insert into test(second_key, text, field_4,status, create_date) ?? ??? ??? ??? ?values ((v*10), ?? ??? ??? ??? ?concat('t',v), ? ? ? ? ? ? ? ? substring(md5(rand()), 1, 10), ? ? ? ? ? ? ? ? 'good', ? ? ? ? ? ? ? ? adddate('1970-01-01', rand(v) * 10000)); ? ? ? ? set v = v + 1; ? ? ?end while; ? ? ? set AUTOCOMMIT = 1; end$$ delimiter ;
查看、刪除存儲過程:
mysql> show procedure status like 'test_insert'; mysql> show create procedure test_insert\G; mysql> drop procedure if exists test_insert;
創(chuàng)建表
CREATE TABLE test ( id INT NOT NULL AUTO_INCREMENT, second_key INT, text VARCHAR(20), field_4 VARCHAR(20), status VARCHAR(10), create_date date, PRIMARY KEY (id), KEY idx_second_key (second_key) ) Engine=InnoDB CHARSET=utf8;
插入100萬條數(shù)據(jù)
mysql> call test_insert(1000000); Query OK, 0 rows affected (31.86 sec)
單個提交
完整寫法
drop procedure if exists test_insert; delimiter $$ create procedure test_insert(n int) ?? ?begin ?? ?declare v int default 0; ?? ?while v < n ?? ??? ?do ?? ??? ??? ??? ?insert into test(second_key, text, field_4,status, create_date) ?? ??? ??? ??? ?values ((v*10), ?? ??? ??? ??? ?concat('t',v), ? ? ? ? ? ? ? ? substring(md5(rand()), 1, 10), ? ? ? ? ? ? ? ? 'good', ? ? ? ? ? ? ? ? adddate('1970-01-01', rand(v) * 10000)); ? ? ? ? set v = v + 1; ? ? ?end while; end$$ delimiter ;
插入1萬條數(shù)據(jù)
mysql> call test_insert(10000); Query OK, 1 row affected (1 min 8.52 sec)
打開另一個窗口查看
mysql> select count(*) from test.test; +----------+ | count(*) | +----------+ | ? ? 1428 | +----------+ 1 row in set (0.00 sec) mysql> select count(*) from test.test; +----------+ | count(*) | +----------+ | ? ? 1598 | +----------+ 1 row in set (0.00 sec) mysql> select count(*) from test.test; +----------+ | count(*) | +----------+ | ? ? 1721 | +----------+ 1 row in set (0.00 sec) mysql> select count(*) from test.test; +----------+ | count(*) | +----------+ | ? ? 1983 | +----------+ 1 row in set (0.00 sec)
結(jié)論
批量提交100萬條數(shù)據(jù)用了30秒,單個提交1萬條數(shù)據(jù)用了1分鐘,對比發(fā)現(xiàn),批量提交的效率遠大于單個提交的效率
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
SQL實戰(zhàn)演練之網(wǎng)上商城數(shù)據(jù)庫用戶信息數(shù)據(jù)操作
一直認為,扎實的SQL功底是一名數(shù)據(jù)分析師的安身立命之本,甚至可以稱得上是所有數(shù)據(jù)從業(yè)者的基本功。當然,這里的SQL絕不單單是寫幾條查詢語句那么簡單,接下來請跟著小編通過案例項目進一步提高SQL的能力吧2021-10-10MySQL 5.7增強版Semisync Replication性能優(yōu)化
這篇文章主要介紹了MySQL 5.7增強版Semisync Replication性能優(yōu)化,本文著重講解支持發(fā)送binlog和接受ack的異步化、支持在事務commit前等待ACK兩項內(nèi)容,需要的朋友可以參考下2015-05-05mysql 導出select語句結(jié)果到excel文件遇到問題及解決方法
這篇文章主要介紹了mysql 導出select語句結(jié)果到excel文件遇到問題及解決方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-09-09