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、說明
這里生成的記錄根據實際情況調整,調用存儲過程后根據具體的情況決定是否需要刪除存儲過程。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
新聞熱點
疑難解答