標籤:mysql
今天學習Mysql,做實驗時想向一個標準插入1000行資料,在oracle中類似於這樣
beginfor i in 1..1000 loopinsert ..end loop;end;/
但是Mysql中不支援匿名塊
百度了一下,方法如下:
首先設定delimiter
delimiter的作用:告訴解譯器,這段命令是否已經結束了,mysql是否可以執行了
預設情況下,delimiter是‘;’但是當我們編寫procedure時,如果是預設設定,那麼一遇到‘;’,mysql就要執行,這是我們不希望看到的
所以我們手動設定delimiter為//
delimiter //create procedure per2() begin declare num int; set num=1; while num < 1000 do insert into per2(name) values(concat("fan", num)); set num=num+1;end while;end //
其中concat(“fan”, num),相當於oracle中fan||i的拼接效果,但是mysql不支援這樣拼接
之後我們要調用這個procedure,才會插入資料
([email protected]) [fandb]> call per2(); -> //Query OK, 1 row affected (0.39 sec)
由於我沒有將delimiter’改回來,所以輸入‘;’後並沒有執行,還需要//
查看庫中的procedure
([email protected]) [fandb]> select name from mysql.proc where db=‘fandb‘ and type=‘procedure‘;+------+| name |+------+| per2 |+------+1 row in set (0.00 sec)
查看建立代碼
([email protected]) [fandb]> show create procedure per2\G*************************** 1. row *************************** Procedure: per2 sql_mode: STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION Create Procedure: CREATE DEFINER=`mysql`@`localhost` PROCEDURE `per2`()begin declare num int; set num=1; while num < 1000 do insert into per2(name) values(concat("fan", num)); set num=num+1;end while;endcharacter_set_client: utf8collation_connection: utf8_general_ci Database Collation: utf8_general_ci1 row in set (0.00 sec)
其他使用方法
while ·· end while:
mysql > DELIMITER //mysql > CREATE PROCEDURE proc4()-> begin-> declare var int;-> set var=0;-> while var<6 do-> insert into t values(var);-> set var=var+1;-> end while;-> end;-> //
? while 條件 do–迴圈體 endwhile
?repeat ·· end repeat:
它在執行操作後檢查結果,而 while 則是執行前迚行檢查。
mysql > DELIMITER //mysql > CREATE PROCEDURE proc5 ()-> begin-> declare v int;-> set v=0;-> repeat-> insert into t values(v);-> set v=v+1;-> until v>=5-> end repeat;-> end;-> //
? repeat–迴圈體 until 迴圈條件 endrepeat;
loop ·· endloop:
loop 迴圈丌需要初始條件,這點和 while 迴圈相似,同時和 repeat 迴圈一樣丌需要結束條
件, leave 詫句的意義是離開迴圈。
mysql > DELIMITER //mysql > CREATE PROCEDURE proc6 ()-> begin-> declare v int;-> set v=0;-> LOOP_LABLE:loop-> insert into t values(v);-> set v=v+1;-> if v >=5 then-> leave LOOP_LABLE;-> end if;-> end loop;-> end;-> //
LABLES 標號:
標號可以用在 begin repeat while 戒者 loop 詫句前,詫句標號叧能在合法的詫句前面使用。
可以跳出迴圈,使運行指令達到複合詫句的最後一步。
Mysql向表中迴圈插入資料