内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

MySQL存儲過程創(chuàng)建使用及實(shí)現(xiàn)數(shù)據(jù)快速插入的方法是什么

本文小編為大家詳細(xì)介紹“MySQL存儲過程創(chuàng)建使用及實(shí)現(xiàn)數(shù)據(jù)快速插入的方法是什么”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“MySQL存儲過程創(chuàng)建使用及實(shí)現(xiàn)數(shù)據(jù)快速插入的方法是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

成都創(chuàng)新互聯(lián)公司,為您提供成都網(wǎng)站建設(shè)公司、成都網(wǎng)站制作、網(wǎng)站營銷推廣、網(wǎng)站開發(fā)設(shè)計,對服務(wù)混凝土泵車等多個行業(yè)擁有豐富的網(wǎng)站建設(shè)及推廣經(jīng)驗(yàn)。成都創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)公司成立于2013年,提供專業(yè)網(wǎng)站制作報價服務(wù),我們深知市場的競爭激烈,認(rèn)真對待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發(fā)展進(jìn)步,是我們永遠(yuǎn)的責(zé)任!

一,存儲過程介紹

自MySQL 5.0 版本開始支持存儲過程。存儲過程(Stored Procedure)是一種在數(shù)據(jù)庫中存儲復(fù)雜程序,以便外部程序調(diào)用的一種數(shù)據(jù)庫對象。

存儲過程是為了完成特定功能的SQL語句集,經(jīng)編譯創(chuàng)建并保存在數(shù)據(jù)庫中,用戶可通過指定存儲過程的名字并給定參數(shù)(需要時)來調(diào)用執(zhí)行。

存儲過程思想就是數(shù)據(jù)庫 SQL 語言層面的代碼封裝與重用。類似于Java開發(fā)中封裝工具類方便以后直接調(diào)用的作用。

二,存儲過程的優(yōu)缺點(diǎn)

優(yōu)點(diǎn)

  • 存儲過程可以一次編譯多次使用。存儲過程只在創(chuàng)建時進(jìn)行編譯,之后的使用都不需要重新編譯,k就提升了sQL的執(zhí)行效率。

  • 可以減少開發(fā)工作量。將代碼封裝成模塊,實(shí)際上是編程的核心思想之一,這樣可以把復(fù)雜的問題拆解成不同的模塊,然后模塊之間可以重復(fù)使用,在減少開發(fā)工作量的同時,還能保證代碼的結(jié)構(gòu)清晰。

  • 存儲過程的安全性強(qiáng)。我們在設(shè)定存儲過程的時候可以設(shè)置對用戶的使用權(quán)限,這樣就和視圖一樣具有較強(qiáng)的安全性。

  • 可以減少網(wǎng)絡(luò)傳輸量。因?yàn)榇a封裝到存儲過程中,每次使用只需要調(diào)用存儲過程即可,這樣就減少了網(wǎng)絡(luò)傳輸量。

  • 良好的封裝性。在進(jìn)行相對復(fù)雜的數(shù)據(jù)庫操作時,原本需要使用一條一條的sQL語句,可能要連接多次數(shù)據(jù)庫才能完成的操作,現(xiàn)在變成了一次存儲過程,只需要連接一次即可。

缺點(diǎn)

  • 可移植性差。存儲過程不能跨數(shù)據(jù)庫移植,比如在MysQL、Oracle和sQL Server里編寫的存儲過程,在換成其他數(shù)據(jù)庫時都需要重新編寫。

  • 調(diào)試?yán)щy。只有少數(shù)DBMS支持存儲過程的調(diào)試。對于復(fù)雜的存儲過程來說,開發(fā)和維護(hù)都不容易。雖然也有一些第三方工具可以對存儲過程進(jìn)行調(diào)試,但要收費(fèi)。

  • 存儲過程的版本管理很困難。比如數(shù)據(jù)表索引發(fā)生變化了,可能會導(dǎo)致存儲過程失效。我們在開發(fā)軟件的時候往往需要進(jìn)行版本管理,但是存儲過程本身沒有版本控制,版本迭代更新的時候很麻煩。

  • 它不適合高并發(fā)的場景。高并發(fā)的場景需要減少數(shù)據(jù)庫的壓力,有時數(shù)據(jù)庫會采用分庫分表的方式,而且對可擴(kuò)展性要求很高,在這種情況下,存儲過程會變得難以維護(hù),增加數(shù)據(jù)庫的壓力,顯然就不適用了。

 三,存儲過程的創(chuàng)建與調(diào)用

  • 存儲過程就是具有名字的一段代碼,用來完成一個特定的功能。

  • 創(chuàng)建的存儲過程保存在數(shù)據(jù)庫的數(shù)據(jù)字典中。

3.1,存儲過程中的常用語法及參數(shù)

聲明語句結(jié)束符,可以自定義:

DELIMITER $$

聲明存儲過程:

CREATE PROCEDURE pro_name(IN num int)

存儲過程開始和結(jié)束符號:

BEGIN .... END

變量賦值:

SET num=1

變量定義:

DECLARE num int unsigned default 100;

創(chuàng)建mysql存儲過程、存儲函數(shù):

create procedure 存儲過程名(參數(shù))

存儲過程體:

create function 存儲函數(shù)名(參數(shù))

參數(shù)解析:

MySQL存儲過程的參數(shù)用在存儲過程的定義,共有三種參數(shù)類型,IN,OUT,INOUT,形式如:

CREATEPROCEDURE 存儲過程名([[IN |OUT |INOUT ] 參數(shù)名 數(shù)據(jù)類形...])

  • IN 輸入?yún)?shù):表示調(diào)用者向過程傳入值(傳入值可以是字面量或變量)

  • OUT 輸出參數(shù):表示過程向調(diào)用者傳出值(可以返回多個值)(傳出值只能是變量)

  • INOUT 輸入輸出參數(shù):既表示調(diào)用者向過程傳入值,又表示過程向調(diào)用者傳出值(值只能是變量)

需要注意的是,這里的參數(shù)根據(jù)需求而定,如果不需要參數(shù),亦可不填寫!

3.2,存儲過程的使用

下面依次根據(jù)實(shí)例對不同的情況進(jìn)行演示:

首先準(zhǔn)備一張my_datas表:

mysql> create table if not exists `my_datas`(
`id` int(20) not null auto_increment comment '數(shù)據(jù)id',
`name` varchar(30) default null comment '姓名',
`address` varchar(45) default null comment '地址',
`time` datetime default null comment '創(chuàng)建時間',
primary key(`id`)
)engine=innodb auto_increment=1 default charset=utf8mb4;
Query OK, 0 rows affected, 1 warning (0.33 sec)

查看結(jié)構(gòu)是否正確:

mysql> show columns from `my_datas`;
+---------+-------------+------+-----+-------------------+-------------------+
| Field   | Type        | Null | Key | Default           | Extra             |
+---------+-------------+------+-----+-------------------+-------------------+
| id      | int         | NO   | PRI | NULL              | auto_increment    |
| name    | varchar(30) | YES  |     | NULL              |                   |
| address | varchar(45) | YES  |     | NULL              |                   |
| time    | datetime    | YES  |     | NULL              | DEFAULT_GENERATED |
+---------+-------------+------+-----+-------------------+-------------------+
4 rows in set (0.00 sec)

(1),創(chuàng)建存儲函數(shù),向數(shù)據(jù)表中插入50條數(shù)據(jù)

mysql> delimiter //    #定義結(jié)束符
mysql> drop procedure if exists addMyData;
    -> create procedure addMyData()  #創(chuàng)建一個存儲過程,名為:addMyData
    -> begin
    -> declare num int;
    -> set num =1;
    -> while num <=50   #插入50條數(shù)據(jù)
    -> do
    -> insert into `my_datas`(id,name,address,time) 
    -> values(null,concat('數(shù)據(jù)_',num,'號'),concat('北京四 合院',round(rand()*10),'號'),concat(current_timestamp()));  #concat函數(shù)拼接信息
    -> set num =num +1;
    -> end
    -> while;
    -> end //;
Query OK, 0 rows affected, 1 warning (0.03 sec)
 
mysql> delimiter;  #將語句的結(jié)束符號恢復(fù)為分號

默認(rèn)情況下,存儲過程和默認(rèn)數(shù)據(jù)庫相關(guān)聯(lián),如果想指定存儲過程創(chuàng)建在某個特定的數(shù)據(jù)庫下,那么在過程名前面加數(shù)據(jù)庫名做前綴。 在定義過程時,使用 DELIMITER //命令將語句的結(jié)束符號從分號 ; 臨時改為兩個//,使得過程體中使用的分號被直接傳遞到服務(wù)器,而不會被客戶端解釋。

調(diào)用存儲函數(shù),并查詢插入結(jié)果

mysql> call addMyData();
Query OK, 1 row affected (0.58 sec)
 
mysql> select * from `my_datas`;
+----+--------------+----------------------+---------------------+
| id | name         | address              | time                |
+----+--------------+----------------------+---------------------+
|  1 | 數(shù)據(jù)_1號     | 北京四合院3號        | 2022-08-24 14:21:17 |
|  2 | 數(shù)據(jù)_2號     | 北京四合院8號        | 2022-08-24 14:21:17 |
|  3 | 數(shù)據(jù)_3號     | 北京四合院4號        | 2022-08-24 14:21:17 |
|  4 | 數(shù)據(jù)_4號     | 北京四合院3號        | 2022-08-24 14:21:17 |
|  5 | 數(shù)據(jù)_5號     | 北京四合院3號        | 2022-08-24 14:21:17 |
|  6 | 數(shù)據(jù)_6號     | 北京四合院7號        | 2022-08-24 14:21:17 |
|  7 | 數(shù)據(jù)_7號     | 北京四合院7號        | 2022-08-24 14:21:17 |
|  8 | 數(shù)據(jù)_8號     | 北京四合院5號        | 2022-08-24 14:21:17 |
|  9 | 數(shù)據(jù)_9號     | 北京四合院1號        | 2022-08-24 14:21:17 |
| 10 | 數(shù)據(jù)_10號    | 北京四合院1號        | 2022-08-24 14:21:17 |
| 11 | 數(shù)據(jù)_11號    | 北京四合院3號        | 2022-08-24 14:21:17 |
| 12 | 數(shù)據(jù)_12號    | 北京四合院1號        | 2022-08-24 14:21:17 |
| 13 | 數(shù)據(jù)_13號    | 北京四合院6號        | 2022-08-24 14:21:17 |
| 14 | 數(shù)據(jù)_14號    | 北京四合院8號        | 2022-08-24 14:21:17 |
| 15 | 數(shù)據(jù)_15號    | 北京四合院3號        | 2022-08-24 14:21:17 |
| 16 | 數(shù)據(jù)_16號    | 北京四合院9號        | 2022-08-24 14:21:17 |
| 17 | 數(shù)據(jù)_17號    | 北京四合院7號        | 2022-08-24 14:21:17 |
| 18 | 數(shù)據(jù)_18號    | 北京四合院8號        | 2022-08-24 14:21:17 |
| 19 | 數(shù)據(jù)_19號    | 北京四合院1號        | 2022-08-24 14:21:17 |
| 20 | 數(shù)據(jù)_20號    | 北京四合院9號        | 2022-08-24 14:21:17 |
| 21 | 數(shù)據(jù)_21號    | 北京四合院2號        | 2022-08-24 14:21:17 |
| 22 | 數(shù)據(jù)_22號    | 北京四合院2號        | 2022-08-24 14:21:17 |
| 23 | 數(shù)據(jù)_23號    | 北京四合院3號        | 2022-08-24 14:21:17 |
| 24 | 數(shù)據(jù)_24號    | 北京四合院10號       | 2022-08-24 14:21:17 |
| 25 | 數(shù)據(jù)_25號    | 北京四合院1號        | 2022-08-24 14:21:17 |
| 26 | 數(shù)據(jù)_26號    | 北京四合院5號        | 2022-08-24 14:21:17 |
| 27 | 數(shù)據(jù)_27號    | 北京四合院1號        | 2022-08-24 14:21:17 |
| 28 | 數(shù)據(jù)_28號    | 北京四合院3號        | 2022-08-24 14:21:17 |
| 29 | 數(shù)據(jù)_29號    | 北京四合院10號       | 2022-08-24 14:21:17 |
| 30 | 數(shù)據(jù)_30號    | 北京四合院10號       | 2022-08-24 14:21:17 |
| 31 | 數(shù)據(jù)_31號    | 北京四合院0號        | 2022-08-24 14:21:17 |
| 32 | 數(shù)據(jù)_32號    | 北京四合院2號        | 2022-08-24 14:21:17 |
| 33 | 數(shù)據(jù)_33號    | 北京四合院8號        | 2022-08-24 14:21:17 |
| 34 | 數(shù)據(jù)_34號    | 北京四合院6號        | 2022-08-24 14:21:17 |
| 35 | 數(shù)據(jù)_35號    | 北京四合院5號        | 2022-08-24 14:21:17 |
| 36 | 數(shù)據(jù)_36號    | 北京四合院7號        | 2022-08-24 14:21:17 |
| 37 | 數(shù)據(jù)_37號    | 北京四合院1號        | 2022-08-24 14:21:17 |
| 38 | 數(shù)據(jù)_38號    | 北京四合院3號        | 2022-08-24 14:21:17 |
| 39 | 數(shù)據(jù)_39號    | 北京四合院3號        | 2022-08-24 14:21:17 |
| 40 | 數(shù)據(jù)_40號    | 北京四合院6號        | 2022-08-24 14:21:17 |
| 41 | 數(shù)據(jù)_41號    | 北京四合院9號        | 2022-08-24 14:21:17 |
| 42 | 數(shù)據(jù)_42號    | 北京四合院7號        | 2022-08-24 14:21:17 |
| 43 | 數(shù)據(jù)_43號    | 北京四合院9號        | 2022-08-24 14:21:17 |
| 44 | 數(shù)據(jù)_44號    | 北京四合院5號        | 2022-08-24 14:21:17 |
| 45 | 數(shù)據(jù)_45號    | 北京四合院8號        | 2022-08-24 14:21:17 |
| 46 | 數(shù)據(jù)_46號    | 北京四合院3號        | 2022-08-24 14:21:17 |
| 47 | 數(shù)據(jù)_47號    | 北京四合院1號        | 2022-08-24 14:21:17 |
| 48 | 數(shù)據(jù)_48號    | 北京四合院7號        | 2022-08-24 14:21:17 |
| 49 | 數(shù)據(jù)_49號    | 北京四合院10號       | 2022-08-24 14:21:17 |
| 50 | 數(shù)據(jù)_50號    | 北京四合院9號        | 2022-08-24 14:21:17 |
+----+--------------+----------------------+---------------------+
50 rows in set (0.00 sec)

這樣,50條需要的數(shù)據(jù)就能快速插入完畢。但是局限性在于插入的數(shù)據(jù)是在定義存儲過程中寫死的,不夠靈活。

(2),in輸入?yún)?shù)的使用

為了方便靈活的插入/修改/刪除/查詢我們需要的數(shù)據(jù),我們可以定義in來輸入?yún)?shù),如下:

創(chuàng)建一個用域刪除指定id信息的存儲過程

mysql> delimiter !!
mysql> create procedure delete_data(in ids int)  #定義一個輸入的參數(shù)
    -> begin
    -> delete from `my_datas` where id=ids;
    -> end !!
Query OK, 0 rows affected (0.05 sec)
mysql> delimiter ;

執(zhí)行存儲過程并查看數(shù)據(jù)庫信息情況:

mysql> call delete_data(3);  #輸入指定參數(shù)
   
Query OK, 1 row affected (0.04 sec)
 
mysql> select * from `my_datas` limit 3;
 
+----+-------------+---------------------+---------------------+
| id | name        | address             | time                |
+----+-------------+---------------------+---------------------+
|  1 | 數(shù)據(jù)_1號    | 北京四合院3號       | 2022-08-24 14:21:17 |
|  2 | 數(shù)據(jù)_2號    | 北京四合院8號       | 2022-08-24 14:21:17 |
|  4 | 數(shù)據(jù)_4號    | 北京四合院3號       | 2022-08-24 14:21:17 |
+----+-------------+---------------------+---------------------+
3 rows in set (0.00 sec)

在存儲過程中設(shè)置了需要傳參的變量ids,調(diào)用存儲過程的時候,通過傳參將3賦值給ids,然后進(jìn)行存儲過程里的SQL操作。  

(3),out參數(shù)的使用

構(gòu)建一個簡單的存儲過程:

mysql> create procedure sums(a int ,b int ,out c int)
    -> begin
    -> set c = a+b;
    -> end //
Query OK, 0 rows affected (0.03 sec)
mysql> delimiter ;

進(jìn)行驗(yàn)證:

mysql> call sums(11,25,@s);
Query OK, 0 rows affected (0.01 sec)
mysql> select @s;  #正常輸出c的值
+------+
| @s   |
+------+
|   36 |
+------+

(4),inout參數(shù)的使用

構(gòu)建一個inout型的存儲過程:

mysql> delimiter //
mysql> create procedure inout_test(inout test int)
    -> begin
    -> select test;
    -> set test=100;
    -> select test;
    -> end
    -> //
Query OK, 0 rows affected (0.07 sec)
 
mysql> delimiter ;

測試執(zhí)行過程:

mysql> set @test=52
    -> ;
Query OK, 0 rows affected (0.00 sec)
 
mysql> call inout_test(@test);
+------+
| test |
+------+
|   52 |
+------+
1 row in set (0.00 sec)
 
+------+
| test |
+------+
|  100 |
+------+
1 row in set (0.00 sec)
 
Query OK, 0 rows affected (0.00 sec)
 
#調(diào)用了inout_param存儲過程,接受了輸入的參數(shù),也輸出參數(shù),改變了變量
mysql> select @test;
+-------+
| @test |
+-------+
|   100 |
+-------+
1 row in set (0.00 sec)

注意事項(xiàng):參數(shù)的名字不要和列名相同,不然在過程體中,參數(shù)名會當(dāng)作列名來處理,并且,存儲過程命名盡量不要跟一些常用函數(shù)命名一樣,否則sql檢查會出錯。

四,存儲過程中的變量及使用細(xì)則

4.1,變量定義

局部變量聲明一定要放在存儲過程體的開始:

DECLARE 變量名  數(shù)據(jù)類型(int,float,date&hellip;&hellip;)

例如:

DECLARE  numbers int  

DECLARE l_datetime datetime DEFAULT '2022-09-31 16:12:35';

DECLARE l_varchar varchar(255) DEFAULT '黎治躍在內(nèi)卷!';

4.2,變量賦值

SET 變量名 = 表達(dá)式值 [,variable_name = expression ...]

4.3,用戶變量的使用

mysql > SELECT '黎治躍在內(nèi)卷' into @l;  
Query OK, 0 rows affected (0.00 sec)
mysql > SELECT @l;  
+-------------+  
|   @l        |  
+-------------+  
| 黎治躍在內(nèi)卷 |  
+-------------+  
1 row in set (0.00 sec)
 
mysql> set @z='做個人吧,黎治躍';
Query OK, 0 rows affected (0.00 sec)
 
mysql> select @z;
+--------------------------+
| @z                       |
+--------------------------+
| 做個人吧,黎治躍         |
+--------------------------+
1 row in set (0.00 sec)
 
mysql> SET @y=5+2+52; 
Query OK, 0 rows affected (0.00 sec)
 
mysql> select @y;
+------+
| @y   |
+------+
|   59 |
+------+
1 row in set (0.00 sec)

存儲過程中使用用戶變量:

mysql> create procedure see() select concat(@lzy,'Java全能選手');
Query OK, 0 rows affected (0.02 sec)
 
mysql> set @lzy ='黎治躍:';
Query OK, 0 rows affected (0.00 sec)
 
mysql> call see();
+---------------------------------+
| concat(@lzy,'Java全能選手')     |
+---------------------------------+
| 黎治躍:Java全能選手            |
+---------------------------------+
1 row in set (0.00 sec)
 
Query OK, 0 rows affected (0.00 sec)

在存儲過程間傳遞全局范圍的用戶變量:

mysql> CREATE PROCEDURE p1()   SET @last_procedure='l1';  
Query OK, 0 rows affected (0.02 sec)
 
mysql> CREATE PROCEDURE p2() SELECT CONCAT('Last procedure was ',@last_procedure);  
Query OK, 0 rows affected (0.03 sec)
 
mysql> CALL p1( );  
mysql> CALL p2( );  
+-----------------------------------------------+  
| CONCAT('Last procedure was ',@last_proc       |  
+-----------------------------------------------+  
| Last procedure was l1                         |  
+-----------------------------------------------+
1 row in set (0.00 sec)
 
Query OK, 0 rows affected (0.00 sec)

注意:

1、用戶變量名一般以@開頭

2、濫用用戶變量會導(dǎo)致程序難以理解及管理

4.4,存儲過程的一些常用查看命令

查看具體存儲過程信息

show create procedure 存儲過程名 \G

查看所有存儲過程

show procedure status \G

模糊查詢對應(yīng)的存儲過程信息

show procedure status like “模糊查詢名” \G

查看指定表中的存儲信息

select * from 表名 where routine_name = '存儲過程名' \G

五,常用的存儲過程的控制語句

5.1,條件語句

5.1.1,if-then-else
mysql > delimiter //  
mysql > create prcedure test2(in s int)  
     -> begin 
     -> declare num int;  
     -> set num=s+1;  
     -> if num=0 then 
     -> insert into `new_table` values(555);  
     -> end if;  
     -> if s=0 then 
     -> update `new_table` set s1=s1+1;  
     -> else 
     -> update `new_table` set s1=s1+2;  
     -> end if;  
     -> end;  
     -> //  
Query OK, 0 rows affected (0.07 sec)
 
mysql > delimiter ;
5.1.2,case語句
mysql > delimiter //  
mysql > create procedure test(in sb int)  
     -> begin 
     -> declare num int;  
     -> set num=sb+1;  
     -> case num  
     -> when 0 then   
     -> insert into `new_table` values(23);  
     -> when 1 then   
     -> insert into `new_table` values(24);  
     -> else   
     -> insert into `new_table` values(25);  
     -> end case;  
     -> end;  
     -> //  
Query OK, 0 rows affected (0.06 sec)
 
mysql > delimiter ;

5.2,循環(huán)語句

5.2.1,while &hellip;&hellip;end while語句
mysql > delimiter //  
mysql > create procedure test()  
     -> begin 
     -> declare num int;  
     -> set num=0;  
     -> while num<6 do  
     -> insert into `new_tables` values(num);  
     -> set num=num+1;  
     -> end while;  
     -> end;  
     -> //  
Query OK, 0 rows affected (0.03 sec)
 
mysql > delimiter ;
5.2.2,repeat&hellip;&hellip;end repeat語句

這個語句與while語句的不同之處在于while是先檢查再執(zhí)行,而repeat語句是執(zhí)行操作后檢查結(jié)果。

mysql > delimiter //  
mysql > create procedure test()  
     -> begin   
     -> declare num int;  
     -> set num=0;  
     -> repeat  
     -> insert into `new_table` values(num);  
     -> set num=num+1;  
     -> until num>=5  #循環(huán)條件
     -> end repeat;  
     -> end;  
     -> //  
 
Query OK, 0 rows affected (0.04 sec)
 
mysql > delimiter ;
5.2.3,loop&hellip;&hellip;end loop語句

loop循環(huán)相當(dāng)于一個while True ...if ... break 循環(huán),與repeat一循環(huán)不同,loop可以在循環(huán)體的任何位置通過leave離開循環(huán),而repeat只能在循環(huán)體最后進(jìn)行until判斷 。此外loop還提供了循環(huán)標(biāo)簽,用于在嵌套&middot;循環(huán)中標(biāo)識不同層次的循環(huán)。

mysql > delimiter //  
mysql > create procedure test5()  
     -> begin 
     -> declare num int;  
     -> set num=0;  
     -> LOOP1:loop  
     -> insert into `new_table` values(num);  
     -> set num=num+1;  
     -> if num >=5 then 
     -> leave LOOP1;  
     -> end if;  
     -> end loop;  
     -> end;  
     -> //  
Query OK, 0 rows affected (0.04 sec)
 
mysql > delimiter ;

六,其他相關(guān)知識點(diǎn)

6.1,存儲過程體

存儲過程體包含了在過程調(diào)用時必須執(zhí)行的語句,例如:dml、ddl語句,if-then-else和while-do語句、聲明變量的declare語句等

過程體格式:以begin開始,以end結(jié)束(可嵌套)

BEGIN
BEGIN
  BEGIN
    statements; 
  END
END
END

每個嵌套塊及其中的每條語句,必須以分號結(jié)束,表示過程體結(jié)束的begin-end塊(又叫做復(fù)合語句compound statement),則不需要分號。

為語句塊貼標(biāo)簽:

label1: BEGIN

   label2: BEGIN

label3: BEGIN

statements;

END label3 ;  

END label2;

END label1

標(biāo)簽有兩個作用:

1、增強(qiáng)代碼的可讀性

2、在某些語句(例如:leave和iterate語句),需要用到標(biāo)簽

6.2,MySQL AlTER命令對表的靈活操作

6.2.1,刪除,添加表字段及默認(rèn)值

刪除表字段

ALTER TABLE 表名  DROP 字段名;

添加表字段

ALTER TABLE 表名 ADD 字段名 字段數(shù)據(jù)類型;

添加表字段默認(rèn)值

ALTER TABLE 表名 ALTER 字段名 SET DEFAULT 默認(rèn)值;

刪除表字段默認(rèn)值

ALTER TABLE 表名 ALTER 字段名 DROP DEFAULT;

另外,如果需要將表字段插入指定的位置,可以使用MySQL提供的關(guān)鍵字 FIRST (設(shè)定位第一列), AFTER 字段名(設(shè)定位于某個字段之后)。使用show columns查看表結(jié)構(gòu)變化:

mysql> show columns from user;
+----------+-------------+------+-----+---------+----------------+
| Field    | Type        | Null | Key | Default | Extra          |
+----------+-------------+------+-----+---------+----------------+
| id       | int         | NO   | PRI | NULL    | auto_increment |
| username | varchar(30) | YES  |     | NULL    |                |
| address  | varchar(45) | YES  |     | NULL    |                |
+----------+-------------+------+-----+---------+----------------+
3 rows in set (0.04 sec)
 
mysql> alter table user add time datetime; #添加一個time字段
Query OK, 0 rows affected (0.17 sec)
Records: 0  Duplicates: 0  Warnings: 0
 
#在address后面添加一個sex字段
mysql> alter table user add sex tinyint(1) after address;Query OK, 0 rows affected, 1 warning (0.41 sec)
Records: 0  Duplicates: 0  Warnings: 1
 
mysql> show columns from user;
+----------+-------------+------+-----+---------+----------------+
| Field    | Type        | Null | Key | Default | Extra          |
+----------+-------------+------+-----+---------+----------------+
| id       | int         | NO   | PRI | NULL    | auto_increment |
| username | varchar(30) | YES  |     | NULL    |                |
| address  | varchar(45) | YES  |     | NULL    |                |
| sex      | tinyint(1)  | YES  |     | NULL    |                |
| time     | datetime    | YES  |     | NULL    |                |
+----------+-------------+------+-----+---------+----------------+
5 rows in set (0.00 sec)
6.2.2,CHANGE與MODIFY對修改字段的作用

當(dāng)需要修改字段類型或者字段名時,常常會使用到change與modify關(guān)鍵字

modify使用

alter table 表名 modify 字段名 字段屬性(更改后)   

modify主要用于更改數(shù)據(jù)字段范圍,當(dāng)遇到在數(shù)據(jù)庫構(gòu)建時,范圍數(shù)據(jù)定義過小,或者范圍數(shù)據(jù)定義過大浪費(fèi)內(nèi)存空間時,對字段屬性的更改。

change使用

alter table 表名 change  old字段名  new字段名  對應(yīng)的字段屬性

change關(guān)鍵字主要用于對字段名的更改,在語法上CHANGE 關(guān)鍵字之后,緊跟著的是你要修改的字段名,然后指定新字段名及類型。但是CHANGE又不僅僅可以更改字段名,它也可以同時修改指明后的字段屬性,同時對字段名和字段屬性進(jìn)行修改。

#使用change僅修改字段名
mysql> alter table user change address address varchar(40); 
Query OK, 499 rows affected (0.38 sec)
Records: 499  Duplicates: 0  Warnings: 0
 
#使用modify僅修改字段屬性
mysql> alter table user modify address varchar(45);
Query OK, 0 rows affected (0.06 sec)
Records: 0  Duplicates: 0  Warnings: 0
 
#使用change同時修改字段名和字段屬性
mysql> alter table user change address u_address varchar(40));
Query OK, 499 rows affected (0.26 sec)
Records: 499  Duplicates: 0  Warnings: 0
 
#查看更改后的表結(jié)構(gòu)
mysql> show columns from user;
+-----------+-------------+------+-----+---------+----------------+
| Field     | Type        | Null | Key | Default | Extra          |
+-----------+-------------+------+-----+---------+----------------+
| id        | int         | NO   | PRI | NULL    | auto_increment |
| username  | varchar(30) | YES  |     | NULL    |                |
| u_address | varchar(40) | YES  |     | NULL    |                |
| sex       | tinyint(1)  | YES  |     | NULL    |                |
| time      | datetime    | YES  |     | NULL    |                |
+-----------+-------------+------+-----+---------+----------------+
5 rows in set (0.01 sec)
6.2.3,其他修改的使用

修改指定表的數(shù)據(jù)引擎

alter table user engine=指定數(shù)據(jù)引擎

例如:ALTER TABLE testalter_tbl ENGINE = MYISAM;

如果對當(dāng)前數(shù)據(jù)表信息不清楚的話可以通過SHOW TABLE STATUS命令進(jìn)行查看。

例如:查看當(dāng)前user表的信息

mysql> show table status like 'user' \G;
*************************** 1. row ***************************
           Name: user
         Engine: InnoDB
        Version: 10
     Row_format: Dynamic
           Rows: 499
 Avg_row_length: 131
    Data_length: 65536
Max_data_length: 0
   Index_length: 0
      Data_free: 0
 Auto_increment: 500
    Create_time: 2022-08-24 17:32:27
    Update_time: NULL
     Check_time: NULL
      Collation: utf8mb4_0900_ai_ci
       Checksum: NULL
 Create_options: 
        Comment: 
1 row in set (0.03 sec)
 
ERROR: 
No query specified

修改表名

alter table old表名 rename to new表名

此外,ALTER關(guān)鍵字的操作也不僅僅局限于操作表,在以后的索引,外鍵上也有很多作用。

讀到這里,這篇“MySQL存儲過程創(chuàng)建使用及實(shí)現(xiàn)數(shù)據(jù)快速插入的方法是什么”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點(diǎn)還需要大家自己動手實(shí)踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前標(biāo)題:MySQL存儲過程創(chuàng)建使用及實(shí)現(xiàn)數(shù)據(jù)快速插入的方法是什么
本文網(wǎng)址:http://m.rwnh.cn/article2/jcggic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、小程序開發(fā)、網(wǎng)站設(shè)計、網(wǎng)頁設(shè)計公司、用戶體驗(yàn)、響應(yīng)式網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
安多县| 临安市| 白水县| 凤冈县| 开远市| 巢湖市| 汝州市| 禹州市| 太原市| 日喀则市| 富裕县| 江源县| 柘城县| 东乌珠穆沁旗| 麻城市| 定州市| 中阳县| 福鼎市| 长岛县| 安平县| 方正县| 桑植县| 定兴县| 堆龙德庆县| 襄垣县| 扎囊县| 汉沽区| 三亚市| 大新县| 湘潭县| 江安县| 陵川县| 德江县| 浦东新区| 阳东县| 福清市| 张家界市| 济宁市| 普宁市| 永靖县| 青铜峡市|