MySql中delimiter究竟可以起到些什麼作用呢?可能不少人都有這樣的疑惑,下文就為您介紹MySql中delimiter的作用,供您參考。
MYSQL匯出一個SQL後:
- DELIMITER $$
- DROP TRIGGER IF EXISTS `updateegopriceondelete`$$
- CREATE
- TRIGGER `updateegopriceondelete` AFTER DELETE ON `customerinfo`
- FOR EACH ROW BEGIN
- DELETE FROM egoprice WHERE customerId=OLD.customerId;
- END$$
- DELIMITER ;
其中DELIMITER 定好結束符為"$$", 然後最後又定義為";", MYSQL的預設結束符為";".
詳細解釋:
其實就是告訴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起到的作用介紹。