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

mysql 如何插入隨機(jī)字符串?dāng)?shù)據(jù)的實(shí)現(xiàn)方法

 更新時(shí)間:2016年09月10日 13:39:48   投稿:mdxy-dxy  
這篇文章主要介紹了mysql 如何插入隨機(jī)字符串?dāng)?shù)據(jù)的實(shí)現(xiàn)方法,需要的朋友可以參考下

應(yīng)用場(chǎng)景:
有時(shí)需要測(cè)試插入數(shù)據(jù)庫(kù)的記錄來(lái)測(cè)試,所以就非常需要用到這些腳本。

創(chuàng)建表:

CREATE TABLE `tables_a` (
  `id` int(10) NOT NULL DEFAULT '0',
  `name` char(50) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

創(chuàng)建產(chǎn)生隨機(jī)字符串的函數(shù):

set global log_bin_trust_function_creators = 1;
DROP FUNCTION IF EXISTS rand_string;
DELIMITER //
CREATE FUNCTION rand_string(n INT)
RETURNS VARCHAR(255)
BEGIN
        DECLARE chars_str varchar(100) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
        DECLARE return_str varchar(255) DEFAULT '';
        DECLARE i INT DEFAULT 0;
        WHILE i < n DO
                SET return_str = concat(return_str,substring(chars_str , FLOOR(1 + RAND()*62 ),1));
                SET i = i +1;
        END WHILE;
        RETURN return_str;
END //
delimiter ; 

創(chuàng)建插入表的procedure,x是從多少開(kāi)始。y是多少結(jié)束,z是產(chǎn)生多少位隨機(jī)數(shù)

delimiter // 
create procedure test(x int(10),y int(10),z int(10))
begin
  DECLARE i INT DEFAULT x;
  while i<y do
 insert into tables_a values(i,rand_string(z));
 set i=i+1;
 end whi

mysql隨機(jī)數(shù)據(jù)生成并插入

dblp數(shù)據(jù)庫(kù)中引用信息很少,平均一篇論文引用0.2篇。使用dblp做實(shí)驗(yàn)數(shù)據(jù)集的某篇論文提到,可以隨機(jī)添加引用信息。受此啟發(fā),我打算為每一篇論文都添加20篇隨機(jī)引用,于是就寫(xiě)出了如下的sql語(yǔ)句:

String sql = "insert into citation(pId1,pId2) values( (select pId from papers limit ?,1),(select pId from papers limit ?,1))";

使用preparedstatement,以batch方式提交數(shù)據(jù)庫(kù)。

第一個(gè)參數(shù)是paper的rowid信息,從0~N(N為papers的total row)。第二個(gè)參數(shù)是Java生成的20個(gè)不重復(fù)的隨機(jī)數(shù),范圍是0-N。然后嵌套在for循環(huán)里,每1w條數(shù)據(jù)提交給數(shù)據(jù)庫(kù)一次。

這段代碼巧妙運(yùn)用limit的特性完成隨機(jī)選tuple,本來(lái)是暗暗得意的。自以為把所有的select都交給數(shù)據(jù)庫(kù)去做了,省去了通過(guò)jdbc的多次連接,應(yīng)該是很快就可以運(yùn)行完成的。哪知,插了不過(guò)10w條(10000*10)數(shù)據(jù),就耗時(shí)22分鐘之多。最終的實(shí)驗(yàn)需要插入400w條數(shù)據(jù),也就是說(shuō)要花14h左右。

于是開(kāi)始反思,不斷做寫(xiě)類似的程序查找時(shí)間瓶頸,最終鎖定在select limit,這個(gè)操作極耗時(shí)間。當(dāng)初選用limit,原因在于:隨機(jī)生成的是數(shù)字,要把數(shù)字映射到tuple,也就是對(duì)應(yīng)到rowid;由于papers表的主鍵并非遞增int,所以默認(rèn)的rowid不存在。后來(lái)一想,可以在papers表上先增加一個(gè)auto_increment的temp列,完成citation插入后再刪除。這樣sql語(yǔ)句就改成了:

String sql = "insert into citation(pId1,pId2) values((select pId from papers where temp=?), (select pId from papers where temp=?))";

再一次插入10w條數(shù)據(jù),耗時(shí)38s。效率大幅提高,但不知道還可不可以進(jìn)一步優(yōu)化。

相關(guān)文章

  • MySQL GTID全面總結(jié)

    MySQL GTID全面總結(jié)

    這篇文章主要介紹了MySQL GTID的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2021-03-03
  • Linux下mysql異地自動(dòng)備份的方法

    Linux下mysql異地自動(dòng)備份的方法

    這篇文章主要介紹了Linux下mysql異地自動(dòng)備份的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • MySQL的字符集操作命令總結(jié)

    MySQL的字符集操作命令總結(jié)

    這篇文章主要介紹了MySQL的字符集操作命令總結(jié),包括各種查看數(shù)據(jù)庫(kù)、數(shù)據(jù)表等查詢命令,需要的朋友可以參考下
    2014-04-04
  • MySQL慢查詢分析工具pt-query-digest詳解

    MySQL慢查詢分析工具pt-query-digest詳解

    pt-query-digest是用于分析mysql慢查詢的一個(gè)工具,它可以分析binlog、General?log、slowlog,也可以通過(guò)SHOWPROCESSLIST或者通過(guò)tcpdump抓取的MySQL協(xié)議數(shù)據(jù)來(lái)進(jìn)行分析,這篇文章主要介紹了MySQL慢查詢分析工具pt-query-digest詳解,需要的朋友可以參考下
    2023-01-01
  • MySQL學(xué)習(xí)第一天 第一次接觸MySQL

    MySQL學(xué)習(xí)第一天 第一次接觸MySQL

    這篇文章是學(xué)習(xí)MySQL的第一篇文章,開(kāi)啟了探究MySQL的奇妙旅程,內(nèi)容主要是對(duì)MySQL的基礎(chǔ)知識(shí)進(jìn)行學(xué)習(xí),了解,感興趣的小伙伴們可以參考一下
    2016-05-05
  • MySQL8.0+版本1045錯(cuò)誤的問(wèn)題及解決辦法

    MySQL8.0+版本1045錯(cuò)誤的問(wèn)題及解決辦法

    這篇文章主要介紹了MySQL8.0+版本1045錯(cuò)誤解決辦法,使用命令行登錄MySQL報(bào)錯(cuò)1045 Access denied for user ‘root’@‘localhost’ (using password:YES),折騰半天才解決問(wèn)題,需要的朋友可以參考下
    2022-08-08
  • MySQL 5.7雙主同步部分表的實(shí)現(xiàn)過(guò)程詳解

    MySQL 5.7雙主同步部分表的實(shí)現(xiàn)過(guò)程詳解

    這篇文章主要給大家介紹了關(guān)于MySQL 5.7雙主同步部分表實(shí)現(xiàn)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • MySQL?UPDATE多表關(guān)聯(lián)更新的實(shí)現(xiàn)示例

    MySQL?UPDATE多表關(guān)聯(lián)更新的實(shí)現(xiàn)示例

    MySQL可以基于多表查詢更新數(shù)據(jù),本文主要介紹了MySQL?UPDATE多表關(guān)聯(lián)更新的實(shí)現(xiàn)示例,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • MySQL教程數(shù)據(jù)定義語(yǔ)言DDL示例詳解

    MySQL教程數(shù)據(jù)定義語(yǔ)言DDL示例詳解

    這篇文章主要為大家介紹了MySQL教程中什么是數(shù)據(jù)定義語(yǔ)言DDL的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-10-10
  • MyEclipse通過(guò)JDBC連接MySQL數(shù)據(jù)庫(kù)基本介紹

    MyEclipse通過(guò)JDBC連接MySQL數(shù)據(jù)庫(kù)基本介紹

    MyEclipse使用Java 通過(guò)JDBC連接MySQL數(shù)據(jù)庫(kù)的基本測(cè)試前提是MyEclipse已經(jīng)能正常開(kāi)發(fā)Java工程
    2012-11-11

最新評(píng)論