青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

woaidongmao

文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見(jiàn)諒!~
隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
數(shù)據(jù)加載中……

MySQL5存儲(chǔ)過(guò)程使用

MySql5.0以后均支持存儲(chǔ)過(guò)程,最近有空,研究了一把這個(gè)

格式:

CREATE PROCEDURE
過(guò)程名 ([過(guò)程參數(shù)[,...]])
[
特性 ...] 過(guò)程體

CREATE FUNCTION
函數(shù)名 ([函數(shù)參數(shù)[,...]])
RETURNS
返回類型
[
特性 ...] 函數(shù)體

過(guò)程參數(shù):
[ IN | OUT | INOUT ]
參數(shù)名 參數(shù)類型

函數(shù)參數(shù):
參數(shù)名 參數(shù)類型

返回類型:
有效的MySQL數(shù)據(jù)類型即可

特性:
LANGUAGE SQL
| [NOT] DETERMINISTIC
| { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
| SQL SECURITY { DEFINER | INVOKER }
| COMMENT 'string'

過(guò)程體/函數(shù)體:格式如下:
BEGIN
有效的SQL語(yǔ)句
END

我在這里不關(guān)心專有的特性,這些與SQL規(guī)范不兼容,所以characteristic(特性)的相關(guān)內(nèi)容不作考慮。
//
在開(kāi)發(fā)過(guò)程中有幾點(diǎn)要注意:
1
、存儲(chǔ)過(guò)程注釋:MySQL支持采用--或者/**/注釋,其中前者是行注釋,后者是段式注釋
2
、變量首先用declare申明,其中臨時(shí)變量可以直接以@前綴修飾以供引用
3
、直接采用MySQLAdministrator管理器編輯時(shí),可以直接采用如下函數(shù)文本錄入;
但若在腳本中自動(dòng)導(dǎo)入存儲(chǔ)過(guò)程或函數(shù)時(shí),由于MySQL默認(rèn)以";"為分隔符,則過(guò)程體的每一句
都被MySQL以存儲(chǔ)過(guò)程編譯,則編譯過(guò)程會(huì)報(bào)錯(cuò);所以要事先用DELIMITER關(guān)鍵字申明當(dāng)前段分隔符
用完了就把分隔符還原。 如下所示:
DELIMITER
$$
Stored Procedures and Functions
DELIMITER ;
4
MySQL支持大量的內(nèi)嵌函數(shù),有些是和大型商用數(shù)據(jù)庫(kù)如oracleinformixsybase等一致,
但也有些函數(shù)名稱不一致,但功能一致;或者有些名稱一致,但功能相異,這個(gè)特別對(duì)于從
這些數(shù)據(jù)庫(kù)開(kāi)發(fā)轉(zhuǎn)過(guò)來(lái)的DBA要注意。
5
、存儲(chǔ)過(guò)程或函數(shù)的調(diào)試:我目前還沒(méi)有研究MySQL所帶的各種工具包,還不清楚其提供了調(diào)試工具
沒(méi)有,不過(guò)編譯錯(cuò)誤相對(duì)好查找;至于業(yè)務(wù)流程的調(diào)試,可以采用一個(gè)比較笨的方法,就是創(chuàng)建一
個(gè)調(diào)試表,在包體中各個(gè)流程點(diǎn)都插入一條記錄,以觀察程序執(zhí)行流程。這也是一個(gè)比較方便的笨
辦法。^_^

下面是2個(gè)例子,提供了一種字串加密的算法,每次以相同的入?yún)⒄{(diào)用都會(huì)得到不同的加密結(jié)果,
算法相對(duì)比較簡(jiǎn)單,不具備強(qiáng)度。分別以函數(shù)和過(guò)程的形式分別實(shí)現(xiàn)如下:
(1)
函數(shù)

eg:
CREATE FUNCTION fun_addmm(inpass varchar(10)) RETURNS varchar(11)
BEGIN
declare string_in varchar(39);
declare string_out varchar(78);
declare offset tinyint(2);
declare outpass varchar(30) default ';
declare len tinyint;
/*declare i tinyint;*/

/**/
set len=LENGTH(inpass);
if((len<=0) or (len>10)) then
return "";
end if;

set offset=(SECOND(NOW()) mod 39)+1; /*
根據(jù)秒數(shù)取模*/
/*insert into testtb values(offset,'offset: ');*/
set string_out='YN8K1JOZVURB3MDETS5GPL27AXWIHQ94C6F0#
_'; /*密鑰*/
set string_in='_
#ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';

set outpass=CONCAT(outpass,SUBSTRING(string_out,offset,1));
/* insert into testtb values(2,outpass);*/
set string_out=CONCAT(string_out,string_out);
set @i=0;
REPEAT
set @i=@i+1;
set outpass=CONCAT(outpass,SUBSTR(string_out,INSTR(string_in,SUBSTRING(inpass,@i,1))+offset,1));
/* insert into testtb values(@i+2,outpass);*/
UNTIL (@i>=len)
end REPEAT;

return outpass;
END


(2)
過(guò)程

CREATE PROCEDURE `pro_addmm`(IN inpass varchar(10),OUT outpass varchar(11))
BEGIN
declare string_in varchar(39);
declare string_out varchar(78);
declare offset tinyint(2);
declare len tinyint;

set outpass=';

set len=LENGTH(inpass);
if((len<=0) or (len>10)) then
set outpass=';
else
set offset=(SECOND(NOW()) mod 39)+1;

set string_out='YN8K1JOZVURB3MDETS5GPL27AXWIHQ94C6F0#
_';
set string_in='_
#ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';

set outpass=CONCAT(outpass,SUBSTRING(string_out,offset,1));

set string_out=CONCAT(string_out,string_out);
set @i=0;
REPEAT
set @i=@i+1;
set outpass=CONCAT(outpass,SUBSTR(string_out,INSTR(string_in,SUBSTRING(inpass,@i,1))+offset,1));
UNTIL (@i>=len)
end REPEAT;
end if;
END


//
執(zhí)行結(jié)果如下:
mysql> call pro_addmm('zhouys',@a);
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT @a;
+---------+
| @a |
+---------+
| U_PI6
4 |
+---------+
1 row in set (0.00 sec)

mysql> call pro_addmm('zhouys',@a);
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT @a;
+---------+
| @a |
+---------+
| 9P8UEGM |
+---------+
1 row in set (0.00 sec)

mysql> select fun_submm('U_PI6
4');
+----------------------+
| fun_submm('U_PI6
4') |
+----------------------+
| ZHOUYS |
+----------------------+
1 row in set (0.00 sec)

加密算法有幾個(gè)弱點(diǎn):
1
、不支持大小寫
2
、不支持中文
3
、加密強(qiáng)度不夠

有興趣的人可以研究一下解密函數(shù)如何編寫,這里就不贅述了。


  1、下載、安裝,不用多說(shuō)(偶喜歡非安裝版,解壓就能用,方便)

  2、啟動(dòng)MySQL 5 :

  開(kāi)啟一個(gè)控制臺(tái),并進(jìn)入到MySQL bin目錄下;

  登錄,輸入: mysql -h localhost -u root -p

  3、選擇一個(gè)數(shù)據(jù)庫(kù): 偶使用test整個(gè)數(shù)據(jù)庫(kù)。這個(gè)庫(kù)沒(méi)有任何的表。

  4、建立一個(gè)表:

  mysql> CREATE TABLE pet (name VARCHAR(20), owner VARCHAR(20),

  -> species VARCHAR(20), sex CHAR(1), birth DATE, death DATE);

  5、插入一行數(shù)據(jù):

  mysql> INSERT INTO pet

  -> VALUES (′Puffball′,′Diane′,′hamster′,′f′,′1999-03-30′,NULL);

  6、創(chuàng)建一個(gè)過(guò)程:

  mysql> delimiter // --- 這是定義結(jié)束符為“//”

  mysql> CREATE PROCEDURE simpleproc (OUT param1 INT)

  -> BEGIN

  -> SELECT COUNT(*) INTO param1 FROM t;

  -> END

  -> //

  Query OK, 0 rows affected (0.00 sec)

  好,一個(gè)過(guò)程創(chuàng)建完畢。

  7、執(zhí)行過(guò)程:

  mysql> delimiter ; --- 這是定義結(jié)束符為“;”,因?yàn)樯厦娑x成了“//”,要改回來(lái),保持習(xí)慣一致。

  mysql> CALL simpleproc(@a);

  Query OK, 0 rows affected (0.00 sec)

  mysql> SELECT @a;

  +------+

  | @a |

  +------+

  | 3 |

  +------+

  1 row in set (0.00 sec)

  哈哈,過(guò)程調(diào)用成功。

 

posted on 2009-08-06 19:33 肥仔 閱讀(295) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)庫(kù)

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一本色道婷婷久久欧美| 亚洲欧美日韩一区二区三区在线| 牛夜精品久久久久久久99黑人| 小黄鸭精品aⅴ导航网站入口| 亚洲天堂成人| 亚洲欧美另类中文字幕| 欧美一级二级三级蜜桃| 欧美一区日韩一区| 久久精品亚洲乱码伦伦中文 | 日韩视频免费观看| 亚洲精品免费一二三区| 亚洲最新在线| 亚洲自拍偷拍一区| 久久视频在线看| 亚洲国产精品精华液网站| 欧美高清一区| 一区二区三欧美| 久久精品国产视频| 欧美日韩网站| 狠狠色丁香久久婷婷综合丁香| 亚洲激情欧美| 久久精品夜色噜噜亚洲a∨| 欧美激情按摩在线| 午夜精品一区二区三区四区| 免费亚洲视频| 国产欧美日韩综合| 在线亚洲欧美专区二区| 猛干欧美女孩| 亚洲欧洲av一区二区三区久久| 老巨人导航500精品| 国产精品国产三级国产a| 在线播放亚洲一区| 先锋影音网一区二区| 亚洲大胆人体在线| 欧美在线精品免播放器视频| 欧美日韩亚洲国产一区| 亚洲电影自拍| 久久久久久久999| 亚洲视频在线观看网站| 久久中文久久字幕| 国产一区二区av| 亚洲午夜精品一区二区三区他趣| 免费看精品久久片| 欧美一级大片在线观看| 欧美日韩免费观看中文| 亚洲经典在线看| 免费观看成人www动漫视频| 午夜精品久久久久| 国产精品手机视频| 亚洲综合第一| 影音先锋日韩有码| 欧美精品一区视频| 在线日韩欧美| 久久人人九九| 欧美一区影院| 国产日韩欧美一二三区| 午夜天堂精品久久久久 | 麻豆亚洲精品| 久久精品国产99国产精品| 国产欧美高清| 久久se精品一区二区| 亚洲欧美日韩天堂| 国产精品你懂的在线| 亚洲在线电影| 亚洲视频综合| 国产精品网站在线观看| 欧美一区影院| 亚洲欧美在线播放| 国产视频亚洲| 美女黄毛**国产精品啪啪| 久久亚洲综合色一区二区三区| 精品91在线| 欧美1级日本1级| 欧美精品免费在线| 亚洲综合日本| 欧美亚洲免费电影| 精品福利免费观看| 亚洲国产岛国毛片在线| 欧美另类女人| 欧美一区网站| 美国成人直播| 亚洲一级特黄| 久久精品国产清高在天天线| 亚洲乱码国产乱码精品精天堂| 日韩午夜电影av| 国产亚洲女人久久久久毛片| 欧美黑人一区二区三区| 欧美午夜精品久久久久久超碰| 欧美一区亚洲一区| 欧美成人69av| 欧美资源在线观看| 欧美激情欧美狂野欧美精品| 午夜精品久久久久久久99水蜜桃 | 久久久久久久一区| 99ri日韩精品视频| 午夜视频在线观看一区二区| 在线观看一区欧美| 一本色道综合亚洲| 亚洲国产成人午夜在线一区| 亚洲手机在线| 亚洲精品老司机| 欧美在线观看你懂的| 中文亚洲字幕| 久久亚洲精品一区| 亚洲欧美日韩国产成人精品影院| 久久久噜噜噜久久| 欧美一级专区| 欧美日韩网址| 亚洲国产欧美一区二区三区久久| 国产欧美不卡| 亚洲人成人一区二区三区| 一区二区三区视频在线观看 | 麻豆国产va免费精品高清在线| 中日韩高清电影网| 午夜精品视频在线观看| 国产主播一区| 亚洲国产高清在线| 亚洲激情欧美| 欧美mv日韩mv国产网站| 亚洲麻豆视频| 久久精品国产亚洲a| 日韩视频一区二区三区在线播放| 亚洲午夜一区二区三区| 亚洲美女免费视频| 久久综合九色欧美综合狠狠| 亚洲尤物影院| 欧美日韩一区二区三区视频| 欧美激情四色 | 黄色成人免费网站| 午夜视频久久久| 亚洲欧美日本伦理| 欧美日韩网址| 亚洲人体影院| 99精品国产福利在线观看免费| 久久精品视频免费| 久久综合网色—综合色88| 国产欧美丝祙| 午夜精品久久久久久久久久久久 | 欧美成人在线影院| 欧美高清影院| 亚洲日本理论电影| 欧美福利视频在线| 亚洲人午夜精品免费| 一本色道**综合亚洲精品蜜桃冫| 欧美国产日本高清在线| 亚洲欧洲偷拍精品| 亚洲一区视频| 国产性天天综合网| 欧美一区二区三区免费在线看 | 嫩草成人www欧美| 亚洲韩国青草视频| 欧美国产在线视频| 宅男噜噜噜66一区二区| 欧美一级专区| 亚洲福利久久| 欧美日韩视频在线第一区| 亚洲午夜精品| 久热re这里精品视频在线6| 亚洲激情亚洲| 国产精品成人aaaaa网站| 在线综合亚洲欧美在线视频| 久久精品理论片| 亚洲人成高清| 国产精品乱码久久久久久| 久久久久9999亚洲精品| 亚洲第一区在线观看| 亚洲影视中文字幕| 亚洲午夜未删减在线观看| 国产欧美综合一区二区三区| 午夜精品福利视频| 免费中文日韩| 亚洲宅男天堂在线观看无病毒| 国产午夜亚洲精品理论片色戒| 嫩草成人www欧美| 亚洲免费视频一区二区| 亚洲国产黄色| 久久精品国产亚洲高清剧情介绍| 亚洲国产日韩欧美在线99| 国产精品日本精品| 欧美精品xxxxbbbb| 久久精品国产成人| 亚洲视频一区二区免费在线观看| 久久伊人精品天天| 一区二区三区国产| 亚洲高清色综合| 国产日韩精品在线播放| 欧美日韩国产在线| 牛牛影视久久网| 久久国产欧美精品| 亚洲一区二区欧美| 亚洲狼人综合| 欧美成人综合网站| 久久人人爽爽爽人久久久| 亚洲欧美日韩区| 一区二区三区 在线观看视频| 18成人免费观看视频| 国产手机视频一区二区| 国产精品久久久久aaaa九色| 欧美精品在线免费播放| 久久婷婷丁香|