MySql中delimiter起到的作用

数据库 MySQL
delimiter在MySql中是非常重要的,下文就将为您详述MySql中delimiter起到的作用,希望能够让您对delimiter有更深刻的认识。

MySql中delimiter究竟可以起到些什么作用呢?可能不少人都有这样的疑惑,下文就为您介绍MySql中delimiter的作用,供您参考。

MYSQL导出一个SQL后:

  1. DELIMITER $$   
  2. DROP TRIGGER IF EXISTS `updateegopriceondelete`$$   
  3. CREATE   
  4.     TRIGGER `updateegopriceondelete` AFTER  DELETE ON  `customerinfo`   
  5.     FOR EACH ROW BEGIN   
  6. DELETE FROM egoprice  WHERE customerId=OLD.customerId;   
  7.     END$$   
  8. DELIMITER ;  

其中DELIMITER 定好结束符为"$$", 然后***又定义为";", MYSQL的默认结束符为";".

详细解释:

其实就是告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。
默认情况下,delimiter是分号;。在命令行客户端中,如果有一行命令以分号结束,
那么回车后,mysql将会执行该命令。如输入下面的语句
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一遇到分号,它就要自动执行。
即,在语句RETURN '';时,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解释器才会执行这段语句

以上就是MySql中delimiter起到的作用介绍。

 

 

 

【编辑推荐】

带参数的MySql存储过程

取得MySQL表信息的语句

mysql插入Clob字段的实例

常见MySql字段的默认长度

MySQL数值数据类型的范围

责任编辑:段燃 来源: 互联网
相关推荐

2010-06-01 11:28:43

MySQL数据库

2018-11-06 10:51:07

Redis开发存储系统

2023-09-14 14:18:27

光纤

2022-06-06 09:41:21

云计算人工智能

2010-06-01 17:21:50

MySQL delim

2013-01-24 09:53:12

GitHub

2009-03-10 18:50:07

服务器虚拟化虚拟化SAN

2009-04-02 18:16:55

Vmware虚拟化服务器

2012-06-01 09:17:19

云计算

2020-02-29 14:41:08

SD-WAN网络NetOps

2017-01-21 21:20:43

2017-10-08 21:55:33

机房空调制冷机柜

2021-04-23 14:33:12

Android 12存储空间代码

2021-07-13 18:31:22

MySQLSQLMode

2018-09-26 05:10:03

物联网云计算IOT

2020-03-11 11:07:08

网络安全保险网络安全

2023-03-08 07:11:45

云原生云计算大数据

2018-02-06 09:13:56

2018-02-09 11:59:37

微信

2018-08-13 16:52:09

人工智能失业科技
点赞
收藏

51CTO技术栈公众号