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

mysql 如何插入隨機字符串數(shù)據的實現(xiàn)方法

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

應用場景:
有時需要測試插入數(shù)據庫的記錄來測試,所以就非常需要用到這些腳本。

創(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)建產生隨機字符串的函數(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是從多少開始。y是多少結束,z是產生多少位隨機數(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隨機數(shù)據生成并插入

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

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

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

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

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

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

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

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

相關文章

  • MySQL GTID全面總結

    MySQL GTID全面總結

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

    Linux下mysql異地自動備份的方法

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

    MySQL的字符集操作命令總結

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

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

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

    MySQL學習第一天 第一次接觸MySQL

    這篇文章是學習MySQL的第一篇文章,開啟了探究MySQL的奇妙旅程,內容主要是對MySQL的基礎知識進行學習,了解,感興趣的小伙伴們可以參考一下
    2016-05-05
  • MySQL8.0+版本1045錯誤的問題及解決辦法

    MySQL8.0+版本1045錯誤的問題及解決辦法

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

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

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

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

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

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

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

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

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

最新評論