>데이터 베이스 >MySQL 튜토리얼 >MySQL 사용자 정의 변수와 명령문 끝 구분 기호의 기본 사항에 대해 이야기해 보겠습니다.

MySQL 사용자 정의 변수와 명령문 끝 구분 기호의 기본 사항에 대해 이야기해 보겠습니다.

WBOY
WBOY앞으로
2022-01-18 18:00:502385검색

이 기사는 mysql의 사용자 정의 변수 및 명령문 끝 구분 기호에 대한 관련 지식을 제공합니다.

MySQL 사용자 정의 변수와 명령문 끝 구분 기호의 기본 사항에 대해 이야기해 보겠습니다.

Stored Programs

때로는 공통 기능을 완성하기 위해 많은 명령문을 실행해야 할 때가 있습니다. 매번 클라이언트에 너무 많은 명령문을 하나씩 입력하는 것은 매우 귀찮은 일입니다. MySQL을 설계한 삼촌은 우리에게 저장 프로시저라는 것을 제공했습니다. 소위 저장 프로시저는 캡슐화된 명령문일 수 있습니다. 사용자에게 이 저장 프로시저를 호출하여 해당 문을 간접적으로 실행할 수 있는 쉬운 방법을 제공합니다. 다양한 호출 방법에 따라 저장 프로시저저장 루틴, 트리거이벤트로 나눌 수 있습니다. 그 중 저장 루틴저장 함수저장 프로시저로 세분화할 수 있습니다. 표현하기 위해 그림을 그려보자: MySQL的大叔非常贴心的给我们提供了一种称之为存储程序的东东,这个所谓的存储程序可以封装一些语句,然后给用户提供一种简单的方式来调用这个存储程序,从而间接地执行这些语句。根据调用方式的不同,我们可以把存储程序分为存储例程触发器事件这几种类型。其中,存储例程又可以被细分为存储函数存储过程。我们画个图表示一下:

MySQL 사용자 정의 변수와 명령문 끝 구분 기호의 기본 사항에 대해 이야기해 보겠습니다.

别看出现了很多陌生的概念,别怕,我们后边会各个击破的。不过在正式介绍存储程序之前,我们需要先了解一下MySQL中的自定义变量和语句结束分隔符的概念。

自定义变量简介

生活中我们经常会遇到一些固定不变的值,比如数字100、字符串'你好呀',我们把这些值固定不变的东东称之为常量。可是有时候为了方便,我们会使用某一个符号来代表一个值,它代表的值是可以变化的。比方说我们规定符号a代表数字1,之后我们又可以让符号a代表数字2,我们把这种值可以发生变化的东东称之为变量,其中符号a就称为这个变量的变量名。在MySQL中,我们可以通过SET语句来自定义一些我们自己的变量,比方说这样:

mysql> SET @a = 1;
Query OK, 0 rows affected (0.00 sec)

mysql>

上边的语句就表明我们定义了一个称之为a的变量,并且把整数1赋值给了这个变量。不过大家需要注意一下,设计MySQL的大叔规定,在我们的自定义变量前边必须加一个@符号(虽然有点儿怪,但这就是人家规定的,大家遵守就好了)。

如果我们之后想查看这个变量的值的话,使用SELECT语句就好了,不过仍然需要在变量名称前加一个@符号:

mysql> SELECT @a;
+------+
| @a   |
+------+
|    1 |
+------+
1 row in set (0.00 sec)

mysql>

同一个变量也可以存储存储不同类型的值,比方说我们再把一个字符串值赋值给变量a

mysql> SET @a = '哈哈哈';
Query OK, 0 rows affected (0.01 sec)

mysql> SELECT @a;
+-----------+
| @a        |
+-----------+
| 哈哈哈    |
+-----------+
1 row in set (0.00 sec)

mysql>

除了把一个常量赋值给一个变量以外,我们还可以把一个变量赋值给另一个变量:

mysql> SET @b = @a;
Query OK, 0 rows affected (0.00 sec)

mysql> select @b;
+-----------+
| @b        |
+-----------+
| 哈哈哈    |
+-----------+
1 row in set (0.00 sec)

mysql>

这样变量ab就有了相同的值'哇哈哈'

我们还可以将某个查询的结果赋值给一个变量,前提是这个查询的结果只有一个值:

mysql> SET @a = (SELECT m1 FROM t1 LIMIT 1);
Query OK, 0 rows affected (0.00 sec)

mysql>

还可以用另一种形式的语句来将查询的结果赋值给一个变量:

mysql> SELECT n1 FROM t1 LIMIT 1 INTO @b;
Query OK, 1 row affected (0.00 sec)

mysql>

因为语句SELECT m1 FROM t1 LIMIT 1SELECT n1 FROM t1 LIMIT 1的查询结果都只有一个值,所以它们可以直接赋值给变量a或者b。我们查看一下这两个变量的值:

mysql> SELECT @a, @b;
+------+------+
| @a   | @b   |
+------+------+
|    1 | a    |
+------+------+
1 row in set (0.00 sec)

mysql>

如果我们的查询结果是一条记录,该记录中有多个列的值的话,我们想把这几个值分别赋值到不同的变量中,只能使用INTO语句了:

mysql> SELECT m1, n1 FROM t1 LIMIT 1 INTO @a, @b;
Query OK, 1 row affected (0.00 sec)

mysql>

这条查询语句的结果集中只包含一条记录,我们把这条记录的m1列的值赋值到了变量a中,n1列的值赋值到了变量b中。

语句结束分隔符

MySQL客户端的交互界面处,当我们完成键盘输入并按下回车键时,MySQL客户端会检测我们输入的内容中是否包含;g或者G这三个符号之一,如果有的话,会把我们输入的内容发送到服务器。这样一来,如果我们想一次性给服务器发送多条的话,就需要把这些语句写到一行中,比如这样:

mysql> SELECT * FROM t1 LIMIT 1;SELECT * FROM t2 LIMIT 1;SELECT * FROM t3 LIMIT 1;
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m2   | n2   |
+------+------+
|    2 | b    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m3   | n3   |
+------+------+
|    3 | c    |
+------+------+
1 row in set (0.00 sec)

mysql>

造成这一不便的原因在于,MySQL客户端检测输入结束用的符号和分隔各个语句的符号是一样的!其实我们也可以用delimiter命令来自定义MySQL的检测语句输入结束的符号,也就是所谓的语句结束分隔符

MySQL 사용자 정의 변수와 명령문 끝 구분 기호의 기본 사항에 대해 이야기해 보겠습니다.

🎜낯설은 개념이 많다고 걱정하지 마세요. 나중에 분해해 보겠습니다. 그러나 저장 프로시저를 공식적으로 도입하기 전에 먼저 MySQL의 사용자 정의 변수 및 명령문 끝 구분 기호의 개념을 이해해야 합니다. 🎜🎜맞춤 변수 소개🎜🎜생활에서 우리는 종종 숫자 100, 문자열 'Hello'와 같은 고정된 값을 접하게 됩니다. 값을 상수라고 합니다. 그러나 편의상 특정 기호를 사용하여 값을 나타내는 경우도 있으며, 해당 기호가 나타내는 값은 변경될 수 있습니다. 예를 들어 a 기호가 숫자 1을 나타내도록 지정한 다음 a 기호가 숫자 2를 나타내도록 할 수 있습니다. . 이렇게 값이 바뀔 수 있는 것을 변수라고 하고, a 기호를 이것의 변수 이름이라고 합니다. 변하기 쉬운. MySQL에서는 SET 문을 통해 자체 변수 중 일부를 사용자 정의할 수 있습니다. 예: 🎜
mysql> delimiter $
mysql> SELECT * FROM t1 LIMIT 1;
    -> SELECT * FROM t2 LIMIT 1;
    -> SELECT * FROM t3 LIMIT 1;
    -> $
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m2   | n2   |
+------+------+
|    2 | b    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m3   | n3   |
+------+------+
|    3 | c    |
+------+------+
1 row in set (0.00 sec)

mysql>
🎜위 문은 a이고 정수 1가 이 변수에 할당됩니다. 하지만 모두가 주의해야 할 점은 MySQL을 설계한 삼촌이 사용자 정의 변수 앞에 @ 기호를 추가해야 한다고 규정했습니다(좀 이상하지만 다른 사람들도 그렇게 규정했기 때문에 모두가 그냥 준수하면 됩니다). 🎜🎜나중에 이 변수의 값을 확인하려면 SELECT 문을 사용하면 됩니다. 하지만 변수 이름 앞에 @ 기호를 추가해야 합니다. 🎜
mysql> delimiter EOF
mysql> SELECT * FROM t1 LIMIT 1;
    -> SELECT * FROM t2 LIMIT 1;
    -> SELECT * FROM t3 LIMIT 1;
    -> EOF
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m2   | n2   |
+------+------+
|    2 | b    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m3   | n3   |
+------+------+
|    3 | c    |
+------+------+
1 row in set (0.00 sec)

mysql>
🎜동일 변수는 다양한 유형의 값을 저장할 수도 있습니다. 예를 들어 변수 a에 문자열 값을 할당합니다. 🎜
mysql> delimiter ;
🎜변수에 상수를 할당하는 것 외에도 변수를 다른 변수에 할당: 🎜rrreee🎜이런 식으로 변수 ab'Wahaha'와 같은 값을 갖습니다! 🎜🎜쿼리 결과에 하나의 값만 있는 경우 쿼리 결과를 변수에 할당할 수도 있습니다. 🎜rrreee🎜다른 형식의 문을 사용하여 쿼리 결과를 변수에 할당할 수도 있습니다. 🎜 rrreee 🎜SELECT m1 FROM t1 LIMIT 1SELECT n1 FROM t1 LIMIT 1 문의 쿼리 결과에는 값이 하나만 있기 때문에 변수 a 또는 b. 다음 두 변수의 값을 확인해 보겠습니다. 🎜rrreee🎜쿼리 결과가 레코드에 여러 열 값이 있는 레코드인 경우 이 값을 다른 변수에 할당하려고 합니다. INTO 문이 사용됩니다: 🎜rrreee🎜이 쿼리 문의 결과 집합에는 하나의 레코드만 포함됩니다. 이 레코드의 m1 열 값을 변수에 할당합니다. , n1 열의 값이 변수 b에 할당됩니다. 🎜🎜문 구분 기호 끝🎜🎜 MySQL 클라이언트의 대화형 인터페이스에서 키보드 입력을 완료하고 Enter 키를 누르면 MySQL 클라이언트가 입력을 감지합니다. 콘텐츠에 ;, g 또는 G 세 가지 기호 중 하나가 포함되어 있나요? 그렇다면 입력한 콘텐츠가 서버로 전송됩니다. . 이런 식으로 한 번에 여러 명령문을 서버에 보내려면 다음과 같이 한 줄에 해당 명령문을 작성해야 합니다. 🎜rrreee🎜이러한 불편을 초래하는 이유는 MySQL 클라이언트 입력의 끝을 감지하는 데 사용되는 기호는 각 명령문을 구분하는 기호와 동일합니다! 실제로 delimiter 명령을 사용하여 MySQL에 대한 기호를 사용자 정의하여 소위 end-of라고 불리는 명령문 입력의 끝을 감지할 수도 있습니다. -문 구분 기호, 예:🎜
mysql> delimiter $
mysql> SELECT * FROM t1 LIMIT 1;
    -> SELECT * FROM t2 LIMIT 1;
    -> SELECT * FROM t3 LIMIT 1;
    -> $
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m2   | n2   |
+------+------+
|    2 | b    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m3   | n3   |
+------+------+
|    3 | c    |
+------+------+
1 row in set (0.00 sec)

mysql>

delimiter $命令意味着修改语句结束分隔符为$,也就是说之后MySQL客户端检测用户语句输入结束的符号为$。上边例子中我们虽然连续输入了3个以分号;结尾的查询语句并且按了回车键,但是输入的内容并没有被提交,直到敲下$符号并回车,MySQL客户端才会将我们输入的内容提交到服务器,此时我们输入的内容里已经包含了3个独立的查询语句了,所以返回了3个结果集。

我们也可以将语句结束分隔符重新定义为$以外的其他包含单个或多个字符的字符串,比方说这样:

mysql> delimiter EOF
mysql> SELECT * FROM t1 LIMIT 1;
    -> SELECT * FROM t2 LIMIT 1;
    -> SELECT * FROM t3 LIMIT 1;
    -> EOF
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m2   | n2   |
+------+------+
|    2 | b    |
+------+------+
1 row in set (0.00 sec)

+------+------+
| m3   | n3   |
+------+------+
|    3 | c    |
+------+------+
1 row in set (0.00 sec)

mysql>

我们这里采用了EOF作为MySQL客户端检测输入结束的符号,是不是很easy啊!当然,这个只是为了方便我们一次性输入多个语句,在输入完成之后最好还是改回我们常用的分号;吧:

mysql> delimiter ;

小贴士: 我们应该避免使用反斜杠(\)字符作为语句结束分隔符,因为这是MySQL的转义字符。

推荐学习:mysql视频教程

위 내용은 MySQL 사용자 정의 변수와 명령문 끝 구분 기호의 기본 사항에 대해 이야기해 보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제