Mysql向表中迴圈插入資料

來源:互聯網
上載者:User

標籤: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向表中迴圈插入資料

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.