中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linux中mysql如何通過存儲過程實現批量生成記錄

發布時間:2021-06-24 12:21:23 來源:億速云 閱讀:206 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關Linux中mysql如何通過存儲過程實現批量生成記錄,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

Linux 下mysql通過存儲過程實現批量生成記錄

在開發中有一個這樣的需求:需要在數據庫的表中生成大量的記錄,這些記錄只有很少的差別,只會在創建表的時候進行一次這個操作。當然,要是人工一條一條的做也不是不可以,也可以用外部的程序來完成,但是這里我選擇使用mysql的存儲過程來實現。

0、相關版本信息

        mysql使用官方打包發布的5.6.29版本,安裝在linux上

1、數據表結構

        表有一個自增的主鍵,另外有一個字段是需要保存的有少許差異的信息,另外有一個字段是其他信息,創建表的代碼:

DROP TABLE IF EXISTS `t_vpn_ip`;
CREATE TABLE `t_vpn_ip` (
  `r_id`       int(16)     NOT NULL  AUTO_INCREMENT,
  `ipaddr`      varchar(16)   NOT NULL  UNIQUE,
  `cc_id`       int(16)     NOT NULL  DEFAULT 0,
  PRIMARY KEY (`r_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

2、存儲過程的創建、調用、刪除

        存儲過程中使用循環來生成大量的記錄。由于這個生成操作只執行一次,所以在調用后就將其刪除。

/**
 * 實現對VPN地值使用情況表的填充
 * 172.16.0.1--172.16.255.254
 */
DROP PROCEDURE IF EXISTS `vpn_addr_fill`;
DELIMITER ;;
CREATE PROCEDURE `vpn_addr_fill`()
BEGIN
  declare i int;
  declare j int;
  SET i=0;
  WHILE i<=255 DO
    SET j=1;
    WHILE j<255 DO
      INSERT INTO t_vpn_ip(ipaddr) VALUES(concat("172.16.",i,".",j));
      SET j = j + 1;
    END WHILE;
    SET i = i + 1;
  END WHILE;
END
;;
DELIMITER ;

/**
 * 填充數據
 */
call vpn_addr_fill();

/**
 * “功成身退”,刪除存儲過程
 */
DROP PROCEDURE IF EXISTS `vpn_addr_fill`;

3、說明

        這里生成的記錄根據實際情況調整,調用存儲過程后根據具體的情況決定是否需要刪除存儲過程。

關于“Linux中mysql如何通過存儲過程實現批量生成記錄”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

天等县| 普格县| 罗平县| 汽车| 阜新市| 轮台县| 会同县| 安阳县| 涞水县| 通山县| 祁连县| 滁州市| 越西县| 普兰县| 青冈县| 应城市| 揭阳市| 乐都县| 宜兰县| 涟水县| 庆安县| 阿拉善盟| 沙洋县| 衡阳县| 长垣县| 南陵县| 尚志市| 淳安县| 尚义县| 商洛市| 玉林市| 黄梅县| 裕民县| 华安县| 孟村| 望城县| 清水县| 团风县| 阜新| 鹤峰县| 定边县|