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

牽著老婆滿街逛

嚴(yán)以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

MySql中delimiter的作用是什么?

轉(zhuǎn)載自:http://www.cnblogs.com/rootq/archive/2009/05/27/1490523.html

這個命令與存儲過程沒什么關(guān)系吧。
其實就是告訴mysql解釋器,該段命令是否已經(jīng)結(jié)束了,mysql是否可以執(zhí)行了。
默認(rèn)情況下,delimiter是分號;。在命令行客戶端中,如果有一行命令以分號結(jié)束,
那么回車后,mysql將會執(zhí)行該命令。如輸入下面的語句
mysql> select * from test_table;
然后回車,那么MySQL將立即執(zhí)行該語句。

但有時候,不希望MySQL這么做。在為可能輸入較多的語句,且語句中包含有分號。
如試圖在命令行客戶端中輸入如下語句
mysql> CREATE FUNCTION `SHORTEN`(S VARCHAR(255), N INT)
mysql>     RETURNS varchar(255)
mysql> BEGIN
mysql> IF ISNULL(S) THEN
mysql>    RETURN '';
mysql> ELSEIF N<15 THEN
mysql>     RETURN LEFT(S, N);
mysql> ELSE
mysql>     IF CHAR_LENGTH(S) <=N THEN
mysql>    RETURN S;
mysql>     ELSE
mysql>    RETURN CONCAT(LEFT(S, N-10), '...', RIGHT(S, 5));
mysql>     END IF;
mysql> END IF;
mysql> END;

默認(rèn)情況下,不可能等到用戶把這些語句全部輸入完之后,再執(zhí)行整段語句。
因為mysql一遇到分號,它就要自動執(zhí)行。
即,在語句RETURN '';時,mysql解釋器就要執(zhí)行了。
這種情況下,就需要事先把delimiter換成其它符號,如//或$$。
mysql> delimiter //
mysql> CREATE FUNCTION `SHORTEN`(S VARCHAR(255), N INT)
mysql>     RETURNS varchar(255)
mysql> BEGIN
mysql> IF ISNULL(S) THEN
mysql>    RETURN '';
mysql> ELSEIF N<15 THEN
mysql>     RETURN LEFT(S, N);
mysql> ELSE
mysql>     IF CHAR_LENGTH(S) <=N THEN
mysql>    RETURN S;
mysql>     ELSE
mysql>    RETURN CONCAT(LEFT(S, N-10), '...', RIGHT(S, 5));
mysql>     END IF;
mysql> END IF;
mysql> END;//

這樣只有當(dāng)//出現(xiàn)之后,mysql解釋器才會執(zhí)行這段語句

 

例子:

mysql> delimiter // 

mysql> CREATE PROCEDURE simpleproc (OUT param1 INT) 
-> BEGIN 
-> SELECT COUNT(*) INTO param1 FROM t; 
-> END; 
-> // 
Query OK, 0 rows affected (0.00 sec) 

mysql> delimiter ; 

mysql> CALL simpleproc(@a); 
Query OK, 0 rows affected (0.00 sec) 

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

 

 

 

 

本文代碼在 MySQL 5.0.41-community-nt 下運行通過。

編寫了個統(tǒng)計網(wǎng)站訪問情況(user agent)的 MySQL 存儲過程。就是下面的這段 SQL 代碼。

drop procedure if exists pr_stat_agent;
-- call pr_stat_agent ('2008-07-17', '2008-07-18')
create procedure pr_stat_agent
(
pi_date_from date
,pi_date_to date
)
begin
-- check input
if (pi_date_from is null) then
set pi_date_from = current_date();
end if;
if (pi_date_to is null) then
set pi_date_to = pi_date_from;
end if;
set pi_date_to = date_add(pi_date_from, interval 1 day);
-- stat
select agent, count(*) as cnt
from apache_log
where request_time >= pi_date_from
and request_time < pi_date_to
group by agent
order by cnt desc;
end;

我在 EMS SQL Manager 2005 for MySQL 這個 MySQL 圖形客戶端下可以順利運行。但是在 SQLyog MySQL GUI v5.02 這個客戶端就會出錯。最后找到原因是沒有設(shè)置好 delimiter 的問題。默認(rèn)情況下,delimiter “;” 用于向 MySQL 提交查詢語句。在存儲過程中每個 SQL 語句的結(jié)尾都有個 “;”,如果這時候,每逢 “;” 就向 MySQL 提交的話,當(dāng)然會出問題了。于是更改 MySQL 的 delimiter,上面 MySQL 存儲過程就編程這樣子了:

delimiter //; -- 改變 MySQL delimiter 為:“//”
drop procedure if exists pr_stat_agent //
-- call pr_stat_agent ('2008-07-17', '2008-07-18')
create procedure pr_stat_agent
(
pi_date_from date
,pi_date_to date
)
begin
-- check input
if (pi_date_from is null) then
set pi_date_from = current_date();
end if;
if (pi_date_to is null) then
set pi_date_to = pi_date_from;
end if;
set pi_date_to = date_add(pi_date_from, interval 1 day);
-- stat
select agent, count(*) as cnt
from apache_log
where request_time >= pi_date_from
and request_time < pi_date_to
group by agent
order by cnt desc;
end; //
delimiter ; // -- 改回默認(rèn)的 MySQL delimiter:“;”

當(dāng)然,MySQL delimiter 符號是可以自由設(shè)定的,你可以用 “/” 或者“$$” 等。但是 MySQL 存儲過程中比較常見的用法是 “//” 和 “$$”。上面的這段在 SQLyog 中的代碼搬到 MySQL 命令客戶端(MySQL Command Line Client)卻不能執(zhí)行。

mysql> delimiter //; -- 改變 MySQL delimiter 為:“//”
mysql>
mysql> drop procedure if exists pr_stat_agent //
->
-> -- call pr_stat_agent ('2008-07-17', '2008-07-18')
->
-> create procedure pr_stat_agent
-> (
-> pi_date_from date
-> ,pi_date_to date
-> )
-> begin
-> -- check input
-> if (pi_date_from is null) then
-> set pi_date_from = current_date();
-> end if;
->
-> if (pi_date_to is null) then
-> set pi_date_to = pi_date_from;
-> end if;
->
-> set pi_date_to = date_add(pi_date_from, interval 1 day);
->
-> -- stat
-> select agent, count(*) as cnt
-> from apache_log
-> where request_time >= pi_date_from
-> and request_time < pi_date_to
-> group by agent
-> order by cnt desc;
-> end; //
->
-> delimiter ; // -- 改回默認(rèn)的 MySQL delimiter:“;”
-> //
-> //
-> //
-> ;
-> ;
->

真是奇怪了!最后終于發(fā)現(xiàn)問題了,在 MySQL 命令行下運行 “delimiter //; ” 則 MySQL 的 delimiter 實際上是 “//;”,而不是我們所預(yù)想的 “//”。其實只要運行指令 “delimiter //” 就 OK 了。

mysql> delimiter // -- 末尾不要符號 “;”
mysql>
mysql> drop procedure if exists pr_stat_agent //
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> -- call pr_stat_agent ('2008-07-17', '2008-07-18')
mysql>
mysql> create procedure pr_stat_agent
-> (
-> pi_date_from date
-> ,pi_date_to date
-> )
-> begin
-> -- check input
-> if (pi_date_from is null) then
-> set pi_date_from = current_date();
-> end if;
->
-> if (pi_date_to is null) then
-> set pi_date_to = pi_date_from;
-> end if;
->
-> set pi_date_to = date_add(pi_date_from, interval 1 day);
->
-> -- stat
-> select agent, count(*) as cnt
-> from apache_log
-> where request_time >= pi_date_from
-> and request_time < pi_date_to
-> group by agent
-> order by cnt desc;
-> end; //
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> delimiter ; -- 末尾不要符號 “//”
mysql>

順帶一提的是,我們可以在 MySQL 數(shù)據(jù)庫中執(zhí)行在文件中的 SQL 代碼。例如,我把上面存儲過程的代碼放在文件 d:\pr_stat_agent.sql 中??梢赃\行下面的代碼建立存儲過程。

mysql> source d:\pr_stat_agent.sql
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)

source 指令的縮寫形式是:“\.”

mysql> \. d:\pr_stat_agent.sql
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)

最后,可見 MySQL 的客戶端工具在有些地方是各自為政,各有各的一套。

posted on 2014-06-13 11:51 楊粼波 閱讀(675) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲特色特黄| 亚洲国产婷婷综合在线精品 | 亚洲综合丁香| 9人人澡人人爽人人精品| 亚洲精品久久久久| 欧美91福利在线观看| 麻豆freexxxx性91精品| 麻豆精品网站| 亚洲精品欧美极品| 亚洲一区日韩在线| 久久精品免费看| 欧美承认网站| 国产精品爱啪在线线免费观看 | 亚洲欧美美女| 久久视频一区| 欧美精品一区三区在线观看| 欧美午夜视频在线观看| 国产一区高清视频| 亚洲精品极品| 午夜日韩激情| 欧美xx69| 亚洲综合好骚| 欧美777四色影视在线| 欧美视频在线观看| 亚洲第一综合天堂另类专| 99在线热播精品免费| 久久gogo国模啪啪人体图| 欧美高清在线播放| 欧美一级一区| 欧美日韩精品三区| 狠狠色2019综合网| 亚洲无线视频| 亚洲第一精品久久忘忧草社区| 亚洲网站在线播放| 欧美激情91| 在线日韩精品视频| 亚洲欧美视频在线观看| 亚洲成人自拍视频| 久久激情网站| 国产麻豆成人精品| 亚洲一区二区在线免费观看视频| 牛人盗摄一区二区三区视频| 亚洲资源av| 欧美涩涩视频| 99国产精品国产精品久久 | 一本色道久久加勒比精品| 99国产精品| 亚洲欧美日韩一区二区三区在线观看| 女人天堂亚洲aⅴ在线观看| 亚洲福利视频网| 欧美在线播放| 国产精品免费视频观看| 一区二区三区精品| 亚洲精品国久久99热| 麻豆av福利av久久av| 国模精品娜娜一二三区| 欧美一区二区日韩一区二区| 亚洲免费电影在线观看| 欧美理论在线播放| 日韩视频一区| 亚洲第一精品福利| 欧美高清视频www夜色资源网| 国产在线精品二区| 久久精品国产久精国产思思| 午夜国产精品视频| 国产欧美日韩亚洲精品| 欧美在线播放| 先锋影院在线亚洲| 狠狠干综合网| 亚洲成在人线av| 欧美福利视频在线| 99国产精品久久久久久久成人热| 亚洲国产欧洲综合997久久| 免费在线欧美黄色| av成人老司机| 亚洲一区二区动漫| 国产一区二区三区黄视频| 久久综合伊人| 欧美国产精品劲爆| 亚洲免费在线电影| 欧美专区日韩视频| 亚洲激情成人| 一区二区三区欧美| 国产视频在线观看一区二区三区 | 国产精品激情电影| 欧美在线免费视屏| 久久久在线视频| 日韩视频永久免费| 亚洲视频欧美在线| 激情综合色丁香一区二区| 欧美激情视频免费观看| 欧美日韩在线电影| 久久国产精品72免费观看| 狂野欧美激情性xxxx| 亚洲视频欧美在线| 久久精品国内一区二区三区| 亚洲伦伦在线| 性欧美xxxx大乳国产app| 亚洲国产日韩一级| 中文欧美日韩| 亚洲国产成人精品久久久国产成人一区 | 亚洲人体偷拍| 日韩西西人体444www| 国产精品视频一区二区三区| 蜜臀91精品一区二区三区| 欧美日韩精品国产| 久久婷婷av| 欧美丝袜一区二区| 欧美大片国产精品| 国产农村妇女精品| 亚洲激情黄色| 激情懂色av一区av二区av| 99日韩精品| 亚洲欧洲日本一区二区三区| 亚洲综合国产| 一区二区日韩| 裸体一区二区| 久久夜色精品国产亚洲aⅴ| 欧美日韩国产影片| 欧美成人亚洲成人| 国产精品电影网站| 亚洲精品美女91| 在线免费一区三区| 午夜视频在线观看一区| 正在播放欧美一区| 欧美国产第二页| 亚洲国产第一页| 精品999在线播放| 久久av在线| 久久久久久久综合| 国产欧美欧美| 亚洲尤物影院| 欧美尤物一区| 国产女主播一区二区三区| 一本一本久久a久久精品牛牛影视| 亚洲东热激情| 麻豆av一区二区三区久久| 美女成人午夜| 亚洲国产精彩中文乱码av在线播放| 久久精品国产96久久久香蕉| 欧美一区二区三区男人的天堂| 国产精品爱啪在线线免费观看| 一本一本久久a久久精品综合妖精| 国产精品99久久久久久白浆小说 | 亚洲激情av| 亚洲精品欧美在线| 欧美精品亚洲精品| 99re6热只有精品免费观看| 正在播放日韩| 国产精品你懂的在线| 亚洲一区二区影院| 久久高清一区| 在线观看视频欧美| 欧美成在线观看| 一区二区三区黄色| 久久激情视频免费观看| 黄色一区二区三区四区| 久久亚洲影音av资源网| 亚洲高清自拍| 欧美粗暴jizz性欧美20| 久久久久亚洲综合| 欧美三级精品| 一区二区高清视频| 亚洲欧美制服中文字幕| 国产精品乱码一区二三区小蝌蚪| 亚洲一区二区伦理| 欧美一区二区高清| 国产亚洲精品久久久久婷婷瑜伽| 欧美一区日韩一区| 免费欧美电影| 亚洲免费观看高清完整版在线观看熊 | 亚洲视频在线观看| 久久美女性网| 日韩午夜在线视频| 国产精品视频1区| 在线日韩中文字幕| 亚洲毛片视频| 欧美无砖砖区免费| 亚洲午夜激情| 久久精品一区四区| 亚洲国产日韩在线| 国产精品麻豆成人av电影艾秋| 欧美一区二区三区免费视| 亚洲高清久久网| 亚洲午夜久久久久久尤物 | 欧美精品久久天天躁| 亚洲视频在线免费观看| 另类激情亚洲| 亚洲欧美在线高清| 日韩系列欧美系列| 国产亚洲精品一区二555| 欧美精品在线一区二区| 久久精品国语| 亚洲欧美日韩国产一区二区三区| 91久久精品日日躁夜夜躁国产| 久久久www成人免费精品| 亚洲午夜日本在线观看| 亚洲美女在线国产| 亚洲国产成人av好男人在线观看| 国产精品网站在线|