ホームページ データベース mysql チュートリアル MySQL数据库中delimiter的作用概述_MySQL

MySQL数据库中delimiter的作用概述_MySQL

Jun 01, 2016 pm 01:51 PM
記事 はい 知識 通訳者

以下的文章主要是向大家描述的是MySQL数据库中delimiter的作用是什么?我们一般都认为这个命令和存储过程关系不大,到底是不是这样的呢?以下的文章将会给你相关的知识,望你会有所收获。

其实就是告诉MySQL解释器,该段命令是否已经结束了,MySQL数据库是否可以执行了。默认情况下,delimiter是分号;。在命令行客户端中,如果有一行命令以分号结束,那么回车后,MySQL将会执行该命令。如输入下面的语句

<ol><li>MySQL> select * from test_table; </li></ol>
ログイン後にコピー

然后回车,那么MySQL将立即执行该语句。

但有时候,不希望MySQL这么做。在为可能输入较多的语句,且语句中包含有分号。如试图在命令行客户端中输入如下语句

<ol>
<li>MySQL> CREATE FUNCTION `SHORTEN`(S VARCHAR(255), N INT)  </li>
<li>MySQL> RETURNS varchar(255)  </li>
<li>MySQL> BEGIN  </li>
<li>MySQL> IF ISNULL(S) THEN  </li>
<li>MySQL> RETURN '';  </li>
<li>MySQL> ELSEIF NMySQL> RETURN LEFT(S, N);  </li>
<li>MySQL> ELSE  </li>
<li>MySQL> IF CHAR_LENGTH(S) MySQL> RETURN S;  </li>
<li>MySQL> ELSE  </li>
<li>MySQL> RETURN CONCAT(LEFT(S, N-10), '...', RIGHT(S, 5));  </li>
<li>MySQL> END IF;  </li>
<li>MySQL> END IF;  </li>
<li>MySQL> END; </li>
</ol>
ログイン後にコピー

默认情况下,不可能等到用户把这些语句全部输入完之后,再执行整段语句。因为MySQL一遇到分号,它就要自动执行。即,在语句RETURN '';时,MySQL数据库解释器就要执行了。这种情况下,就需要事先把delimiter换成其它符号,如//或$$。

<ol>
<li>MySQL> delimiter //  </li>
<li>MySQL> CREATE FUNCTION `SHORTEN`(S VARCHAR(255), N INT)  </li>
<li>MySQL> RETURNS varchar(255)  </li>
<li>MySQL> BEGIN  </li>
<li>MySQL> IF ISNULL(S) THEN  </li>
<li>MySQL> RETURN '';  </li>
<li>MySQL> ELSEIF NMySQL> RETURN LEFT(S, N);  </li>
<li>MySQL> ELSE  </li>
<li>MySQL> IF CHAR_LENGTH(S) MySQL> RETURN S;  </li>
<li>MySQL> ELSE  </li>
<li>MySQL> RETURN CONCAT(LEFT(S, N-10), '...', RIGHT(S, 5));  </li>
<li>MySQL> END IF;  </li>
<li>MySQL> END IF;  </li>
<li>MySQL> END;//  </li>
</ol>
ログイン後にコピー

这样只有当//出现之后,MySQL解释器才会执行这段语句

例子:

<ol>
<li>MySQL> delimiter //   </li>
<li>MySQL> CREATE PROCEDURE simpleproc (OUT param1 INT)   </li>
<li>-> BEGIN   </li>
<li>-> SELECT COUNT(*) INTO param1 FROM t;   </li>
<li>-> END;   </li>
<li>-> //   </li>
<li>Query OK, 0 rows affected (0.00 sec)   </li>
<li>MySQL> delimiter ;   </li>
<li>MySQL> CALL simpleproc(@a);   </li>
<li>Query OK, 0 rows affected (0.00 sec)   </li>
<li>MySQL> SELECT @a;   </li>
<li>+------+   </li>
<li>| @a |   </li>
<li>+------+   </li>
<li>| 3 |   </li>
<li>+------+   </li>
<li>1 row in set (0.00 sec)   </li>
</ol>
ログイン後にコピー

本文代码在 MySQL 5.0.41-community-nt 下运行通过。

编写了个统计网站访问情况(user agent)的 MySQL 数据库存储过程。就是下面的这段 SQL 代码。

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

我在 EMS SQL Manager 2005 for MySQL 这个 MySQL 图形客户端下可以顺利运行。但是在 SQLyog MySQL GUI v5.02 这个客户端就会出错。最后找到原因是没有设置好 delimiter 的问题。

默认情况下,delimiter “;” 用于向 MySQL 提交查询语句。在存储过程中每个 SQL 语句的结尾都有个 “;”,如果这时候,每逢 “;” 就向 MySQL 提交的话,当然会出问题了。于是更改 MySQL 的 delimiter,上面 MySQL 存储过程就编程这样子了:

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

<ol>
<li>drop procedure if exists pr_stat_agent //  </li>
<li>-- call pr_stat_agent ('2008-07-17', '2008-07-18')  </li>
<li>create procedure pr_stat_agent  </li>
<li>(  </li>
<li>pi_date_from date  </li>
<li>,pi_date_to date  </li>
<li>)  </li>
<li>begin  </li>
<li>-- check input  </li>
<li>if (pi_date_from is null) then  </li>
<li>set pi_date_from = current_date();  </li>
<li>end if;  </li>
<li>if (pi_date_to is null) then  </li>
<li>set pi_date_to = pi_date_from;  </li>
<li>end if;  </li>
<li>set pi_date_to = date_add(pi_date_from, interval 1 day);  </li>
<li>-- stat  </li>
<li>select agent, count(*) as cnt  </li>
<li>from apache_log  </li>
<li>where request_time >= pi_date_from  </li>
<li>and request_time group by agent  </li>
<li>order by cnt desc;  </li>
<li>end; //  </li>
<li>
<font style="background-color: #ff0000">delimiter ;</font>  </li>
</ol>
ログイン後にコピー

改回默认的 MySQL delimiter:“;”

当然,MySQL delimiter 符号是可以自由设定的,你可以用 “/” 或者“$$” 等。但是 MySQL数据库 存储过程中比较常见的用法是 “//” 和 “$$”。上面的这段在 SQLyog 中的代码搬到 MySQL 命令客户端(MySQL Command Line Client)却不能执行。

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

<ol>
<li>MySQL> </li>
<li>MySQL> drop procedure if exists pr_stat_agent //  </li>
<li>-> </li>
<li>-> -- call pr_stat_agent ('2008-07-17', '2008-07-18')  </li>
<li>-> </li>
<li>-> create procedure pr_stat_agent  </li>
<li>-> (  </li>
<li>-> pi_date_from date  </li>
<li>-> ,pi_date_to date  </li>
<li>-> )  </li>
<li>-> begin  </li>
<li>-> -- check input  </li>
<li>-> if (pi_date_from is null) then  </li>
<li>-> set pi_date_from = current_date();  </li>
<li>-> end if;  </li>
<li>-> </li>
<li>-> if (pi_date_to is null) then  </li>
<li>-> set pi_date_to = pi_date_from;  </li>
<li>-> end if;  </li>
<li>-> </li>
<li>-> set pi_date_to = date_add(pi_date_from, interval 1 day);  </li>
<li>-> </li>
<li>-> -- stat  </li>
<li>-> select agent, count(*) as cnt  </li>
<li>-> from apache_log  </li>
<li>-> where request_time >= pi_date_from  </li>
<li>-> and request_time -> group by agent  </li>
<li>-> order by cnt desc;  </li>
<li>-> end; //  </li>
<li>-> </li>
<li>-> delimiter ; </li>
</ol>
ログイン後にコピー

改回默认的 MySQL delimiter:“;”

<ol>
<li>-> //  </li>
<li>-> //  </li>
<li>-> //  </li>
<li>-> ;  </li>
<li>-> ;  </li>
<li>-> </li>
</ol>
ログイン後にコピー

真是奇怪了!最后终于发现问题了,在 MySQL 命令行下运行 “delimiter //; ” 则 MySQL 的 delimiter 实际上是 “//;”,而不是我们所预想的 “//”。其实只要运行指令 “delimiter //” 就 OK 了。

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

<ol>
<li>MySQL> </li>
<li>MySQL> drop procedure if exists pr_stat_agent //  </li>
<li>Query OK, 0 rows affected (0.00 sec)  </li>
<li>MySQL> </li>
<li>MySQL> -- call pr_stat_agent ('2008-07-17', '2008-07-18')  </li>
<li>MySQL> </li>
<li>MySQL> create procedure pr_stat_agent  </li>
<li>-> (  </li>
<li>-> pi_date_from date  </li>
<li>-> ,pi_date_to date  </li>
<li>-> )  </li>
<li>-> begin  </li>
<li>-> -- check input  </li>
<li>-> if (pi_date_from is null) then  </li>
<li>-> set pi_date_from = current_date();  </li>
<li>-> end if;  </li>
<li>-> </li>
<li>-> if (pi_date_to is null) then  </li>
<li>-> set pi_date_to = pi_date_from;  </li>
<li>-> end if;  </li>
<li>-> </li>
<li>-> set pi_date_to = date_add(pi_date_from, interval 1 day);  </li>
<li>-> </li>
<li>-> -- stat  </li>
<li>-> select agent, count(*) as cnt  </li>
<li>-> from apache_log  </li>
<li>-> where request_time >= pi_date_from  </li>
<li>-> and request_time -> group by agent  </li>
<li>-> order by cnt desc;  </li>
<li>-> end; //  </li>
<li>Query OK, 0 rows affected (0.00 sec)  </li>
<li>MySQL> </li>
<li>MySQL> delimiter ;   </li>
</ol>
ログイン後にコピー

末尾不要符号 “//”

<ol><li>MySQL> </li></ol>
ログイン後にコピー

顺带一提的是,我们可以在 MySQL 数据库中执行在文件中的 SQL 代码。例如,我把上面存储过程的代码放在文件 d:/pr_stat_agent.sql 中。可以运行下面的代码建立存储过程。

<ol>
<li>MySQL> source d:/pr_stat_agent.sql  </li>
<li>Query OK, 0 rows affected (0.00 sec)  </li>
<li>Query OK, 0 rows affected (0.00 sec)  </li>
</ol>
ログイン後にコピー

source 指令的缩写形式是:“/.”

<ol>
<li>MySQL> /. d:/pr_stat_agent.sql  </li>
<li>Query OK, 0 rows affected (0.00 sec)  </li>
<li>Query OK, 0 rows affected (0.00 sec)  </li>
</ol>
ログイン後にコピー

最后,可见 MySQL数据库的客户端工具在有些地方是各自为政,各有各的一套。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

今すぐ Toutiao の記事を公開してお金を稼ぐにはどうすればよいですか?今すぐ Toutiao で記事を公開して収入を増やす方法! 今すぐ Toutiao の記事を公開してお金を稼ぐにはどうすればよいですか?今すぐ Toutiao で記事を公開して収入を増やす方法! Mar 15, 2024 pm 04:13 PM

1. 今すぐ Toutiao の記事を公開してどうやってお金を稼ぐことができますか?今すぐ Toutiao で記事を公開して収入を増やす方法! 1. 基本的な権利と利益の有効化: オリジナルの記事は広告によって利益を得ることができますが、利益を得るにはビデオが横画面モードでオリジナルである必要があります。 2. ファン100人の権利を有効化:ファン数が100人以上に達すると、マイクロヘッドライン、オリジナルQ&amp;A作成、Q&amp;Aから利益を得ることができます。 3. オリジナル作品にこだわる: オリジナル作品には記事、小見出し、質問などが含まれ、300 ワード以上であることが求められます。違法に盗用された作品をオリジナル作品として出版した場合、クレジットポイントが減点され、利益も差し引かれますのでご注意ください。 4. 垂直性:専門分野の記事を書く場合、分野を超えて自由に記事を書くことができず、適切な推薦が得られず、専門性や洗練度が得られず、ファンもつきにくいそして読者たち。 5. 活動: 高活動、

Windows 11 で Python のインストールを確認する複数の方法 Windows 11 で Python のインストールを確認する複数の方法 Nov 18, 2023 am 11:05 AM

Windows 11 に Python がインストールされているかどうかを確認するさまざまな方法 Python がシステムにまだインストールされていない場合は、Windows 11 で Python と PIP パッケージ マネージャーを取得する単一のコマンドを示す記事を確認してください。 1. コマンドプロンプトを使用する 1 つ目はコマンドラインを使用する方法です。これには Windows の CMD を使用します。これは、ラップトップまたは PC にインストールされている Python のバージョンを確認する最良の方法です。 python--version2.PowerShell コマンド プロンプトと同様に、PowerShell は Windows プラットフォームで利用できる Microsoft のコマンド ライン シェルおよびスクリプト ツールです。

衝撃的な win10x システム知識を学びましょう 衝撃的な win10x システム知識を学びましょう Jul 14, 2023 am 11:29 AM

最近、win10X システムの最新イメージ ダウンロードがインターネット上で流出しましたが、このイメージは一般的な ISO とは異なり .ffu 形式であり、現在は Surface Pro7 エクスペリエンスでのみ使用できます。 Win10x システムの最新評価を見てみましょう! Win10x システムの最新評価 1. Win10X との最大の違いタスク バーの中央にボタンが配置されており、ピン留めされたアプリケーションに加えて、Android や iOS フォンと同様に、最近起動したアプリケーションもタスク バーに表示できます。 2. もう 1 つは、新しいシステムの「スタート」メニューがファイルをサポートしていないことです。

Python の基礎となるテクノロジーの詳細: インタプリタの実装方法 Python の基礎となるテクノロジーの詳細: インタプリタの実装方法 Nov 08, 2023 pm 05:53 PM

Python の基礎となるテクノロジーの詳細な調査: インタプリタの実装方法 はじめに: Python は、ソフトウェア開発およびデータ分析の分野で広く使用されている高水準言語です。習得が簡単で、洗練された構文、動的型付け、オブジェクト指向機能を備えているため、開発者の間で非常に人気があります。ただし、Python がどのようにコードを実行し、さまざまな機能を実装するかという基礎となるテクノロジーに関する理解は限られています。この記事では、Python の基礎となるテクノロジーを詳しく掘り下げ、単純な Python インタープリターを実装し、特定のコードを添付する方法に焦点を当てます。

pycharmでインタープリタを設定する方法 pycharmでインタープリタを設定する方法 Dec 08, 2023 pm 05:32 PM

pycharm でインタープリターを設定する手順: 1. PyCharm を開いてプロジェクトを作成します; 2. プロジェクト設定を開きます; 3. インタープリター構成ページを選択します; 4. インタープリターを構成します。詳細な導入: 1. 1. PyCharm を開いてプロジェクトを作成し、PyCharm IDE を開いて、ようこそインターフェイスまたはメニューで [新しいプロジェクトの作成] を選択して新しいプロジェクトを作成するか、既存のプロジェクトを開きます; 2. プロジェクト設定を開き、プロジェクト 最後に、上部メニューバーの「ファイル」などをクリックします。

PyCharm インタープリターのインストール チュートリアル: Python 環境を簡単に構成する PyCharm インタープリターのインストール チュートリアル: Python 環境を簡単に構成する Feb 22, 2024 pm 11:30 PM

PyCharm インタープリターのインストール チュートリアル: Python 環境を簡単に構成する PyCharm は、Python 開発の分野で広く使用されている強力な統合開発環境です。 Python インタープリターを適切に構成することは、PyCharm を使用するための基礎です。この記事では、初心者がすぐに使い始めることができるように、PyCharm に Python インタープリターをインストールして構成する方法を紹介します。ステップ 1: Python インタープリターをインストールする まず、公式 Web サイト https://www.python.org にアクセスする必要があります。

PyCharm インタープリターによって追加されたトリックの復号化 PyCharm インタープリターによって追加されたトリックの復号化 Feb 21, 2024 pm 03:33 PM

PyCharm インタプリタによって追加されたトリックを解読する PyCharm は、多くの Python 開発者に好まれる統合開発環境 (IDE) であり、開発効率を向上させるための強力な機能を多数提供します。中でもインタプリタの設定は PyCharm の重要な部分であり、インタプリタを正しく設定することで、開発者はコードをスムーズに実行し、プログラムをデバッグすることができます。この記事では、PyCharm インタープリターの追加機能を解読するためのいくつかのテクニックを紹介し、それを特定のコード例と組み合わせて、インタープリターを正しく構成する方法を示します。 Py でのインタープリターの追加と選択

PyCharm でのインタープリター構成の詳細なステップバイステップ分析 PyCharm でのインタープリター構成の詳細なステップバイステップ分析 Feb 03, 2024 am 08:11 AM

PyCharm でインタープリターを構成する手順の詳細な説明には、特定のコード例が必要ですが、Python 開発に PyCharm を使用する場合、インタープリターを正しく構成することは非常に重要な手順です。インタープリターは Python コードが実行される環境であり、PyCharm はプロジェクト コードの実行にどのインタープリターを使用するかを認識する必要があります。この記事では、PyCharm でインタープリターを構成する手順を詳しく説明し、具体的なコード例を示します。ステップ 1: PyCharm を開いてプロジェクトを作成または開く まず、PyCharm を開きます

See all articles