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

牽著老婆滿街逛

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

MySql中delimiter的作用是什么?

轉載自:http://www.cnblogs.com/rootq/archive/2009/05/27/1490523.html

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

但有時候,不希望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;

默認情況下,不可能等到用戶把這些語句全部輸入完之后,再執行整段語句。
因為mysql一遇到分號,它就要自動執行。
即,在語句RETURN '';時,mysql解釋器就要執行了。
這種情況下,就需要事先把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;//

這樣只有當//出現之后,mysql解釋器才會執行這段語句

 

例子:

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 下運行通過。

編寫了個統計網站訪問情況(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 這個客戶端就會出錯。最后找到原因是沒有設置好 delimiter 的問題。默認情況下,delimiter “;” 用于向 MySQL 提交查詢語句。在存儲過程中每個 SQL 語句的結尾都有個 “;”,如果這時候,每逢 “;” 就向 MySQL 提交的話,當然會出問題了。于是更改 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 ; // -- 改回默認的 MySQL delimiter:“;”

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

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 ; // -- 改回默認的 MySQL delimiter:“;”
-> //
-> //
-> //
-> ;
-> ;
->

真是奇怪了!最后終于發現問題了,在 MySQL 命令行下運行 “delimiter //; ” 則 MySQL 的 delimiter 實際上是 “//;”,而不是我們所預想的 “//”。其實只要運行指令 “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 數據庫中執行在文件中的 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)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            99精品免费| 亚洲人体偷拍| 免费视频一区| 亚洲激情在线观看| 亚洲一区二区视频在线观看| 午夜精品久久久久久99热| 亚洲精品免费一二三区| 欧美在现视频| 国产精品免费一区二区三区在线观看 | 欧美伊人久久| 免费一级欧美片在线观看| 99视频精品| 午夜天堂精品久久久久| 欧美在线一二三区| 久久综合九色九九| 久久国产婷婷国产香蕉| 久久天天躁狠狠躁夜夜av| 91久久精品一区二区别| 先锋亚洲精品| 99在线精品视频| 午夜天堂精品久久久久| 久久综合九色| 美玉足脚交一区二区三区图片| 欧美极品在线视频| 亚洲成人在线视频播放 | 亚洲激情影视| 亚洲欧美精品中文字幕在线| 夜夜嗨av色一区二区不卡| 久久婷婷久久| 久久亚洲一区二区| 狠狠做深爱婷婷久久综合一区| 亚洲国产人成综合网站| 欧美在线日韩在线| 亚洲欧美日韩专区| 欧美大片免费| 久久成人一区二区| 欧美三日本三级少妇三2023| 亚洲欧美日韩国产一区二区| 免费成人av在线看| 欧美午夜国产| 久久漫画官网| 国产酒店精品激情| 一区二区三区成人精品| 亚洲精品日韩久久| 亚洲网友自拍| 亚洲精品一线二线三线无人区| 日韩视频―中文字幕| 亚洲精品一区二区三区不| 亚洲一二三级电影| 亚洲视频免费观看| 男女av一区三区二区色多| 一本大道久久a久久精二百| 久久久五月婷婷| 欧美日韩成人在线| 一区二区三区黄色| 9色国产精品| 欧美成人一区二区| 亚洲国产美女精品久久久久∴| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲精品1区| 性欧美video另类hd性玩具| 欧美国产精品| 亚洲欧美电影院| 91久久夜色精品国产九色| 久久综合狠狠综合久久综合88| 性欧美超级视频| 欧美在线一区二区三区| 国产真实乱子伦精品视频| 美日韩丰满少妇在线观看| 久久视频一区二区| 夜夜嗨av一区二区三区网页| 欧美性猛片xxxx免费看久爱| 99re国产精品| 免费精品99久久国产综合精品| 亚洲视频狠狠| 亚洲啪啪91| 欧美日韩国产专区| 在线一区日本视频| 国产在线播放一区二区三区| 欧美日韩在线播放一区| 国产欧美日韩视频在线观看| 亚洲精品一线二线三线无人区| 久久成人18免费网站| 麻豆国产va免费精品高清在线| 国产美女一区| 亚洲精品久久7777| 久久久高清一区二区三区| 亚洲精品一级| 久久人人97超碰国产公开结果| 国产精品magnet| 亚洲欧美日韩成人| 亚洲精品日本| 黄色精品一二区| 久久野战av| 国产午夜久久久久| 欧美系列精品| 国产欧美69| 国产精品卡一卡二| 欧美国产日韩视频| 欧美性开放视频| 亚洲欧美国产精品桃花| 亚洲男人的天堂在线观看| 欧美人成网站| 亚洲欧洲精品一区二区精品久久久| 曰本成人黄色| 免费不卡在线视频| 亚洲人成啪啪网站| 正在播放欧美视频| 国产精品久久久久久久久久ktv| 在线综合亚洲欧美在线视频| 亚洲欧美在线视频观看| 国产精品网站视频| 亚洲一区二区毛片| 黄色成人免费观看| 99国产精品国产精品毛片| 国产欧美一区二区三区久久| 欧美电影电视剧在线观看| 国内成人精品一区| 亚洲国产精品久久久久秋霞不卡| 蜜桃av久久久亚洲精品| 久久久精品tv| 欧美在线视频观看免费网站| 欧美日韩午夜激情| 亚洲电影观看| 亚洲精品久久久久久久久| 亚洲自拍高清| 欧美亚洲专区| 国产伦精品一区二区三区照片91 | 欧美成人高清视频| 日韩视频在线一区二区三区| 国产精品区二区三区日本| 久久嫩草精品久久久精品| 91久久夜色精品国产网站| 欧美在线观看视频一区二区三区 | 久久久亚洲高清| aaa亚洲精品一二三区| 国产精品人人做人人爽| 久久理论片午夜琪琪电影网| 日韩一级成人av| 另类人畜视频在线| 亚洲视频一二区| 亚洲电影自拍| 国产欧美一区二区三区沐欲| 欧美aⅴ一区二区三区视频| 亚洲欧美日韩国产另类专区| 最新中文字幕一区二区三区| 久久视频在线视频| 亚洲欧美日产图| 一本到12不卡视频在线dvd| 在线播放日韩专区| 国产精品一区2区| 欧美网站大全在线观看| 免费亚洲一区二区| 久久九九热re6这里有精品 | 国产精品免费观看视频| 欧美激情日韩| 麻豆成人综合网| 久久精品国产一区二区三区| 亚洲欧美日韩精品久久| 夜夜爽夜夜爽精品视频| 亚洲福利视频二区| 欧美1区2区3区| 老司机一区二区| 久久久久亚洲综合| 久久福利影视| 久久国产乱子精品免费女| 香蕉成人啪国产精品视频综合网| 夜夜爽av福利精品导航| 亚洲精品久久久久久久久| 在线日韩中文| 亚洲国产成人精品久久久国产成人一区| 国产精品一区二区三区四区| 国产精品国产自产拍高清av王其 | 国产一区三区三区| 国产精品人人爽人人做我的可爱| 欧美午夜一区二区| 国产精品国产三级国产专播精品人 | 一本色道久久99精品综合| 亚洲伦理自拍| 在线视频一区二区| 亚洲丝袜av一区| 亚洲综合欧美日韩| 性欧美1819性猛交| 久久成人精品无人区| 久久精品国产99国产精品| 久久高清一区| 久热re这里精品视频在线6| 久久三级视频| 欧美激情视频网站| 国产日韩欧美精品| 国产精品一区二区三区免费观看| 国产精品久久久久久一区二区三区| 欧美三级电影网| 国产精品社区| 影音先锋中文字幕一区| 亚洲人成在线播放网站岛国| 一区二区三区精品视频在线观看| 一区二区三区欧美视频| 午夜精品久久久久久久99黑人| 欧美在线视频导航|