Rumah pangkalan data tutorial mysql MySQL数据库中delimiter的作用概述_MySQL

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

Jun 01, 2016 pm 01:51 PM
artikel ya Pengetahuan jurubahasa

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

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

<ol><li>MySQL> select * from test_table; </li></ol>
Salin selepas log masuk

然后回车,那么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>
Salin selepas log masuk

默认情况下,不可能等到用户把这些语句全部输入完之后,再执行整段语句。因为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>
Salin selepas log masuk

这样只有当//出现之后,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>
Salin selepas log masuk

本文代码在 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>
Salin selepas log masuk

我在 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>
Salin selepas log masuk

改回默认的 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>
Salin selepas log masuk

改回默认的 MySQL delimiter:“;”

<ol>
<li>-> //  </li>
<li>-> //  </li>
<li>-> //  </li>
<li>-> ;  </li>
<li>-> ;  </li>
<li>-> </li>
</ol>
Salin selepas log masuk

真是奇怪了!最后终于发现问题了,在 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>
Salin selepas log masuk

末尾不要符号 “//”

<ol><li>MySQL> </li></ol>
Salin selepas log masuk

顺带一提的是,我们可以在 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>
Salin selepas log masuk

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>
Salin selepas log masuk

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

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimanakah saya boleh membuat wang dengan menerbitkan artikel di Toutiao hari ini? Bagaimana untuk mendapatkan lebih banyak pendapatan dengan menerbitkan artikel di Toutiao hari ini! Bagaimanakah saya boleh membuat wang dengan menerbitkan artikel di Toutiao hari ini? Bagaimana untuk mendapatkan lebih banyak pendapatan dengan menerbitkan artikel di Toutiao hari ini! Mar 15, 2024 pm 04:13 PM

1. Bagaimanakah anda boleh membuat wang dengan menerbitkan artikel di Toutiao hari ini? Bagaimana untuk mendapatkan lebih banyak pendapatan dengan menerbitkan artikel di Toutiao hari ini! 1. Aktifkan hak dan kepentingan asas: Artikel asal boleh memperoleh keuntungan melalui pengiklanan dan video mestilah asli dalam mod skrin mendatar untuk memperoleh keuntungan. 2. Aktifkan hak 100 peminat: jika bilangan peminat mencecah 100 peminat ke atas, anda boleh mendapat keuntungan daripada tajuk mikro, ciptaan Soal Jawab asal dan Soal Jawab. 3. Menegaskan karya asli: Karya asal termasuk artikel, tajuk mikro, soalan, dsb., dan dikehendaki melebihi 300 patah perkataan. Sila ambil perhatian bahawa jika karya yang diciplak secara haram diterbitkan sebagai karya asli, mata kredit akan ditolak, malah sebarang keuntungan akan ditolak. 4. Ketegakan: Apabila menulis artikel dalam bidang profesional, anda tidak boleh menulis artikel merentas bidang sesuka hati Anda tidak akan mendapat cadangan yang sesuai, anda tidak akan dapat mencapai profesionalisme dan ketepatan kerja, dan sukar untuk menarik peminat. dan pembaca. 5. Aktiviti: aktiviti tinggi,

Pelbagai Cara untuk Mengesahkan Pemasangan Python Windows 11 Pelbagai Cara untuk Mengesahkan Pemasangan Python Windows 11 Nov 18, 2023 am 11:05 AM

Cara yang berbeza untuk menyemak sama ada Python dipasang dalam Windows 11 Jika Python belum dipasang pada sistem anda, maka anda boleh menyemak artikel kami yang menunjukkan satu arahan untuk mendapatkan pengurus pakej Python dan PIP pada Windows 11. 1. Menggunakan Command Prompt Kaedah pertama adalah menggunakan baris arahan, untuk ini kami menggunakan CMD Windows. Ini adalah cara terbaik untuk mengetahui versi Python yang dipasang pada komputer riba atau PC anda. python--version2.PowerShell adalah serupa dengan Command Prompt PowerShell ialah shell baris arahan dan alat skrip Microsoft yang tersedia pada platform Windows.

Biarkan anda belajar tentang pengetahuan sistem win10x yang mengejutkan Biarkan anda belajar tentang pengetahuan sistem win10x yang mengejutkan Jul 14, 2023 am 11:29 AM

Baru-baru ini, muat turun imej terbaharu sistem win10X telah dibocorkan di Internet Berbeza daripada ISO biasa, imej ini dalam format .ffu dan pada masa ini hanya boleh digunakan untuk pengalaman Surface Pro7. Walaupun ramai rakan tidak dapat mengalaminya, anda masih boleh membaca kandungan penilaian yang berkaitan dan berseronok, jadi mari kita lihat penilaian terbaru sistem win10x Penilaian terbaru sistem win10x 1. Perbezaan terbesar antara Win10X dan Win10 mula-mula muncul selepas but butang diletakkan di tengah-tengah bar tugas Selain aplikasi yang disematkan, bar tugas juga boleh memaparkan aplikasi yang dilancarkan baru-baru ini, sama seperti telefon Android dan iOS. 2. Perkara lain ialah menu “Mula” sistem baharu tidak menyokong fail

Menyelam mendalam ke dalam teknologi asas Python: cara melaksanakan penterjemah Menyelam mendalam ke dalam teknologi asas Python: cara melaksanakan penterjemah Nov 08, 2023 pm 05:53 PM

Penerokaan mendalam tentang teknologi asas Python: Cara melaksanakan jurubahasa Pengenalan: Python ialah bahasa peringkat tinggi yang digunakan secara meluas dalam bidang pembangunan perisian dan analisis data. Ia mudah dipelajari, mempunyai sintaks yang elegan, menaip dinamik dan ciri berorientasikan objek, jadi ia sangat popular di kalangan pembangun. Walau bagaimanapun, pemahaman kami tentang teknologi asas tentang cara Python melaksanakan kod dan melaksanakan pelbagai fungsi adalah terhad. Artikel ini akan menyelidiki teknologi asas Python, memfokuskan pada cara melaksanakan penterjemah Python yang mudah dan melampirkan kod tertentu.

Tutorial pemasangan jurubahasa PyCharm: konfigurasikan persekitaran Python dengan mudah Tutorial pemasangan jurubahasa PyCharm: konfigurasikan persekitaran Python dengan mudah Feb 22, 2024 pm 11:30 PM

Tutorial pemasangan penterjemah PyCharm: Konfigurasikan persekitaran Python dengan mudah PyCharm ialah persekitaran pembangunan bersepadu yang berkuasa yang digunakan secara meluas dalam bidang pembangunan Python. Mengkonfigurasi penterjemah Python dengan betul adalah asas untuk menggunakan PyCharm Artikel ini akan memperkenalkan cara memasang dan mengkonfigurasi penterjemah Python dalam PyCharm untuk membantu pemula bermula dengan cepat. Langkah 1: Pasang penterjemah Python Mula-mula, anda perlu pergi ke laman web rasmi https://www.python.org

Bagaimana untuk menyediakan jurubahasa dalam pycharm Bagaimana untuk menyediakan jurubahasa dalam pycharm Dec 08, 2023 pm 05:32 PM

Langkah-langkah untuk menyediakan penterjemah dalam pycharm: 1. Buka PyCharm dan buat projek 2. Buka tetapan projek 3. Pilih halaman konfigurasi penterjemah; Pengenalan terperinci: 1. 1. Buka PyCharm dan buat projek, buka PyCharm IDE, dan pilih "Buat Projek Baharu" dalam antara muka atau menu alu-aluan untuk mencipta projek baharu, atau buka projek sedia ada 2. Buka tetapan projek, buka projek Akhir sekali, klik "Fail" pada bar menu atas dan seterusnya.

Menyahsulit helah yang ditambahkan oleh jurubahasa PyCharm Menyahsulit helah yang ditambahkan oleh jurubahasa PyCharm Feb 21, 2024 pm 03:33 PM

Menyahsulit helah yang ditambahkan oleh penterjemah PyCharm PyCharm ialah persekitaran pembangunan bersepadu (IDE) yang digemari oleh ramai pembangun Python, dan ia menyediakan banyak ciri berkuasa untuk meningkatkan kecekapan pembangunan. Antaranya, tetapan penterjemah adalah bahagian penting PyCharm Menetapkan penterjemah dengan betul boleh membantu pembangun menjalankan kod dengan lancar dan menyahpepijat program. Artikel ini akan memperkenalkan beberapa teknik untuk menyahsulit penambahan penterjemah PyCharm dan menggabungkannya dengan contoh kod khusus untuk menunjukkan cara mengkonfigurasi penterjemah dengan betul. Menambah dan memilih jurubahasa dalam Py

Analisis langkah demi langkah terperinci untuk mengkonfigurasi penterjemah dalam PyCharm Analisis langkah demi langkah terperinci untuk mengkonfigurasi penterjemah dalam PyCharm Feb 03, 2024 am 08:11 AM

Penjelasan terperinci tentang langkah-langkah untuk mengkonfigurasi penterjemah dalam PyCharm memerlukan contoh kod khusus Apabila menggunakan PyCharm untuk pembangunan Python, mengkonfigurasi penterjemah dengan betul adalah langkah yang sangat penting. Jurubahasa ialah persekitaran di mana kod Python dilaksanakan, dan PyCharm perlu mengetahui penterjemah mana yang hendak digunakan untuk menjalankan kod projek. Artikel ini akan memperincikan langkah untuk mengkonfigurasi penterjemah dalam PyCharm dan memberikan contoh kod khusus. Langkah 1: Buka PyCharm dan buat atau buka projek Pertama, buka PyCharm

See all articles