欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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實戰(zhàn)演練之網(wǎng)上商城數(shù)據(jù)庫用戶信息數(shù)據(jù)操作

    一直認為,扎實的SQL功底是一名數(shù)據(jù)分析師的安身立命之本,甚至可以稱得上是所有數(shù)據(jù)從業(yè)者的基本功。當然,這里的SQL絕不單單是寫幾條查詢語句那么簡單,接下來請跟著小編通過案例項目進一步提高SQL的能力吧
    2021-10-10
  • Mysql高性能優(yōu)化技能總結(jié)

    Mysql高性能優(yōu)化技能總結(jié)

    這篇文章主要介紹了Mysql高性能優(yōu)化技能總結(jié)的相關資料,需要的朋友可以參考下
    2020-02-02
  • MySQL的視圖和索引用法與區(qū)別詳解

    MySQL的視圖和索引用法與區(qū)別詳解

    這篇文章主要介紹了MySQL的視圖和索引用法與區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • 深入MYSQL中的COLLATE

    深入MYSQL中的COLLATE

    MYSQL COLLATE是用于指定字符集的排序規(guī)則的關鍵詞,它可以用于在查詢中對字符數(shù)據(jù)進行排序和比較,具有一定的參考價值,感興趣的可以了解一下
    2023-08-08
  • mysql學習筆記之完整的select語句用法實例詳解

    mysql學習筆記之完整的select語句用法實例詳解

    這篇文章主要介紹了mysql學習筆記之完整的select語句用法,結(jié)合實例形式詳細分析了mysql select語句各種常見參數(shù)、使用方法及操作注意事項,需要的朋友可以參考下
    2020-04-04
  • Mysql并發(fā)常見的死鎖及解決方法

    Mysql并發(fā)常見的死鎖及解決方法

    死鎖是在并發(fā)執(zhí)行的過程中,兩個或多個事務相互等待對方釋放資源的情況,本文主要介紹了Mysql并發(fā)常見的死鎖及解決方法,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • MySQL 5.7增強版Semisync Replication性能優(yōu)化

    MySQL 5.7增強版Semisync Replication性能優(yōu)化

    這篇文章主要介紹了MySQL 5.7增強版Semisync Replication性能優(yōu)化,本文著重講解支持發(fā)送binlog和接受ack的異步化、支持在事務commit前等待ACK兩項內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • 一起了解了解MySQL存儲引擎

    一起了解了解MySQL存儲引擎

    大家好,本篇文章主要講的是一起了解了解MySQL存儲引擎,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • mysql 導出select語句結(jié)果到excel文件遇到問題及解決方法

    mysql 導出select語句結(jié)果到excel文件遇到問題及解決方法

    這篇文章主要介紹了mysql 導出select語句結(jié)果到excel文件遇到問題及解決方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • MySql分表、分庫、分片和分區(qū)知識點介紹

    MySql分表、分庫、分片和分區(qū)知識點介紹

    數(shù)據(jù)庫的數(shù)據(jù)量達到一定程度之后,為避免帶來系統(tǒng)性能上的瓶頸。需要進行數(shù)據(jù)的處理,采用的手段是分區(qū)、分片、分庫、分表,這里就為大家介紹一下,需要的朋友可以參考下
    2020-02-02

最新評論