MySQL数据库中delimiter的作用概述

以下的稿子主假如向大家陈说的是MySQL数据库中delimiter的效应是什么?大家一般都以为那么些命令和储存进度关系相当小,到底是否如此的啊?以下的篇章将会给你相关的学问,望你会有所收获。

骨子里正是报告MySQL解释器,该段命令是或不是已经甘休了,MySQL数据库是不是可以实施了。暗中认可情状下,delimiter是分号;。在指令行顾客端中,如若有一行命令以分集团甘休,那么回车的后边,MySQL将会推行该命令。如输入上边包车型大巴话语

  1. MySQL> select * from test_table; 

接下来回车,那么MySQL将马上实践该语句。

但临时,不希望MySQL这么做。在为大概输入比较多的言语,且语句中包罗有分号。如试图在指令行客商端中输入如下语句

  1. MySQL> CREATE FUNCTION `SHORTEN`(S VARCHAR(255), N INT)
     
  2. MySQL> RETURNS varchar(255)  
  3. MySQL> BEGIN  
  4. MySQL> IF ISNULL(S) THEN  
  5. MySQL> RETURN ”;  
  6. MySQL> ELSEIF N<15 THEN  
  7. MySQL> RETURN LEFT(S, N);  
  8. MySQL> ELSE  
  9. MySQL> IF CHAR_LENGTH(S) <=N THEN  
  10. MySQL> RETURN S;  
  11. MySQL> ELSE  
  12. MySQL> RETURN CONCAT(LEFT(S, N-10), ‘…’, RIGHT(S, 5));
     
  13. MySQL> END IF;  
  14. MySQL> END IF;  
  15. MySQL> END; 

私下认可情状下,不容许等到顾客把这个话语全体输入完现在,再举行整段语句。因为MySQL一超越分号,它就要活动施行。即,在语句RETUEscortN
”;时,MySQL数据库解释器就要试行了。这种气象下,就供给事先把delimiter换到另外符号,如//或$$。

  1. MySQL> delimiter //  
  2. MySQL> CREATE FUNCTION `SHORTEN`(S VARCHAR(255), N INT)
     
  3. MySQL> RETURNS varchar(255)  
  4. MySQL> BEGIN  
  5. MySQL> IF ISNULL(S) THEN  
  6. MySQL> RETURN ”;  
  7. MySQL> ELSEIF N<15 THEN  
  8. MySQL> RETURN LEFT(S, N);  
  9. MySQL> ELSE  
  10. MySQL> IF CHAR_LENGTH(S) <=N THEN  
  11. MySQL> RETURN S;  
  12. MySQL> ELSE  
  13. MySQL> RETURN CONCAT(LEFT(S, N-10), ‘…’, RIGHT(S, 5));
     
  14. MySQL> END IF;  
  15. MySQL> END IF;  
  16. MySQL> END;//  

像这种类型只有当//出现之后,MySQL解释器才会进行这段语句

 

例子:

 

  1. MySQL> delimiter //   
  2. MySQL> CREATE PROCEDURE simpleproc (OUT param1 INT) 
     
  3. -> BEGIN   
  4. -> SELECT COUNT(*) INTO param1 FROM t; 
     
  5. -> END;   
  6. -> //   
  7. Query OK, 0 rows affected (0.00 sec)   
  8. MySQL> delimiter ;   
  9. MySQL> CALL simpleproc(@a);   
  10. Query OK, 0 rows affected (0.00 sec)   
  11. MySQL> SELECT @a;   
  12. +——+   
  13. | @a |   
  14. +——+   
  15. | 3 |   
  16. +——+   
  17. 1 row in set (0.00 sec)   

 

正文代码在 MySQL 5.0.41-community-nt 下运营通过。

编排了个总括网址访谈景况(user agent)的 MySQL
数据仓库储存款和储蓄进度。就是上边的这段 SQL 代码。

 

  1. drop procedure if exists pr_stat_agent;  
  2. — call pr_stat_agent (‘2008-07-17’, ‘2008-07-18’)  
  3. create procedure pr_stat_agent  
  4. (  
  5. pi_date_from date  
  6. ,pi_date_to date  
  7. )  
  8. begin  
  9. — check input  
  10. if (pi_date_from is null) then  
  11. set pi_date_from = current_date();  
  12. end if;  
  13. if (pi_date_to is null) then  
  14. set pi_date_to = pi_date_from;  
  15. end if;  
  16. set pi_date_to = date_add(pi_date_from, interval 1 day);
     
  17. — stat  
  18. select agent, count(*) as cnt  
  19. from apache_log  
  20. where request_time >= pi_date_from  
  21. and request_time < pi_date_to 
  22. group by agent  
  23. order by cnt desc;  
  24. end;  

 

自家在 EMS SQL Manager 2007 for MySQL 这几个 MySQL
图形顾客端下能够顺遂运转。可是在 SQLyog MySQL GUI v5.02
那一个客商端就能够出错。最终找到原因是尚未设置好 delimiter 的主题素材。

暗中认可景况下,delimiter “;” 用于向 MySQL 提交查询语句。在存款和储蓄进度中各种SQL 语句的最终都有个 “;”,借使此时,每逢 “;” 就向 MySQL
提交的话,当然会出难题了。于是更换 MySQL 的 delimiter,上面 MySQL
存款和储蓄进度就编制程序那标准了:

delimiter //; — 改变 MySQL delimiter 为:“//”

 

  1. drop procedure if exists pr_stat_agent //  
  2. — call pr_stat_agent (‘2008-07-17’, ‘2008-07-18’)  
  3. create procedure pr_stat_agent  
  4. (  
  5. pi_date_from date  
  6. ,pi_date_to date  
  7. )  
  8. begin  
  9. — check input  
  10. if (pi_date_from is null) then  
  11. set pi_date_from = current_date();  
  12. end if;  
  13. if (pi_date_to is null) then  
  14. set pi_date_to = pi_date_from;  
  15. end if;  
  16. set pi_date_to = date_add(pi_date_from, interval 1 day);
     
  17. — stat  
  18. select agent, count(*) as cnt  
  19. from apache_log  
  20. where request_time >= pi_date_from  
  21. and request_time < pi_date_to 
  22. group by agent  
  23. order by cnt desc;  
  24. end; //  
  25. delimiter ;  

改回默许的 MySQL delimiter:“;”

理之当然,MySQL delimiter 符号是足以轻巧设定的,你能够用 “/” 也许“$$”
等。可是 MySQL数据库 存款和储蓄进度中比较宽泛的用法是 “//” 和
“$$”。上边的这段在 SQLyog 中的代码搬到 MySQL 命令客户端(MySQL Command
Line Client)却不能够实施。

MySQL> delimiter //; — 改变 MySQL delimiter 为:“//”

  1. MySQL> 
  2. MySQL> drop procedure if exists pr_stat_agent //
     
  3. -> 
  4. -> — call pr_stat_agent (‘2008-07-17’, ‘2008-07-18’)
     
  5. -> 
  6. -> create procedure pr_stat_agent  
  7. -> (  
  8. -> pi_date_from date  
  9. -> ,pi_date_to date  
  10. -> )  
  11. -> begin  
  12. -> — check input  
  13. -> if (pi_date_from is null) then  
  14. -> set pi_date_from = current_date();  
  15. -> end if;  
  16. -> 
  17. -> if (pi_date_to is null) then  
  18. -> set pi_date_to = pi_date_from;  
  19. -> end if;  
  20. -> 
  21. -> set pi_date_to = date_add(pi_date_from, interval 1 day);
     
  22. -> 
  23. -> — stat  
  24. -> select agent, count(*) as cnt  
  25. -> from apache_log  
  26. -> where request_time >= pi_date_from  
  27. -> and request_time < pi_date_to 
  28. -> group by agent  
  29. -> order by cnt desc;  
  30. -> end; //  
  31. -> 
  32. -> delimiter ; 

改回暗许的 MySQL delimiter:“;”

  1. -> //  
  2. -> //  
  3. -> //  
  4. -> ;  
  5. -> ;  
  6. -> 

当成出人意料了!最后终于发掘标题了,在 MySQL 命令行下运行 “delimiter //; ”
则 MySQL 的 delimiter 实际上是 “//;”,并非我们所预期的
“//”。其实假使运营指令 “delimiter //” 就 OK 了。

MySQL> delimiter // — 末尾不要符号 “;”

  1. MySQL> 
  2. MySQL> drop procedure if exists pr_stat_agent //
     
  3. Query OK, 0 rows affected (0.00 sec)  
  4. MySQL> 
  5. MySQL> — call pr_stat_agent (‘2008-07-17’, ‘2008-07-18’)
     
  6. MySQL> 
  7. MySQL> create procedure pr_stat_agent
     
  8. -> (  
  9. -> pi_date_from date  
  10. -> ,pi_date_to date  
  11. -> )  
  12. -> begin  
  13. -> — check input  
  14. -> if (pi_date_from is null) then  
  15. -> set pi_date_from = current_date();  
  16. -> end if;  
  17. -> 
  18. -> if (pi_date_to is null) then  
  19. -> set pi_date_to = pi_date_from;  
  20. -> end if;  
  21. -> 
  22. -> set pi_date_to = date_add(pi_date_from, interval 1 day);
     
  23. -> 
  24. -> — stat  
  25. -> select agent, count(*) as cnt  
  26. -> from apache_log  
  27. -> where request_time >= pi_date_from  
  28. -> and request_time < pi_date_to 
  29. -> group by agent  
  30. -> order by cnt desc;  
  31. -> end; //  
  32. Query OK, 0 rows affected (0.00 sec)  
  33. MySQL> 
  34. MySQL> delimiter ;   

提起底不要符号 “//”

  1. MySQL> 

顺带一提的是,我们得以在 MySQL 数据库中实施在文件中的 SQL
代码。举个例子,笔者把地方存款和储蓄进程的代码放在文件 d:\pr_stat_agent.sql
中。能够运营上面包车型大巴代码建构存款和储蓄进程。

 

  1. MySQL> source d:\pr_stat_agent.sql  
  2. Query OK, 0 rows affected (0.00 sec)  
  3. Query OK, 0 rows affected (0.00 sec)  

 

source 指令的缩写格局是:“\.”

 

  1. MySQL> \. d:\pr_stat_agent.sql  
  2. Query OK, 0 rows affected (0.00 sec)  
  3. Query OK, 0 rows affected (0.00 sec)  

 

终极,可知 MySQL数据库的顾客端工具在多少地方是分别为政,各有各的一套。

Post Author: admin

发表评论

电子邮件地址不会被公开。 必填项已用*标注