有时候为了完成一个经常使用的功能须要执行许多条语句,每次都在客户端里一条一条的去输入这么多语句是很烦的,咱们但愿有一种批处理的形式,让咱们以很简单的方式一次性的执行完这些语句,MySQL
中的存储程序
本质上封装了一些可执行的语句,而后给用户提供一种简单的调用方式来执行这些语句,根据调用方式的不一样,咱们能够把存储程序
分为存储例程
、触发器
和事件
这几种类型。其中,存储例程
又能够被细分为存储函数
和存储过程
。咱们画个图表示一下:mysql
在正式介绍存储程序
以前,咱们须要先了解一下MySQL
中的自定义变量和复合语句的概念。程序员
变量
是和常量
相对的,通常的程序语言都提供对变量的支持,MySQL
中对咱们自定义的变量的命名有个要求,那就是变量名称前必须加一个@
符号。咱们自定义变量的值的类型能够是任意MySQL
支持的类型,比方说咱们来自定义一个变量:sql
mysql> SET @a = 1;
Query OK, 0 rows affected (0.00 sec)
mysql>
复制代码
咱们自定义了一个名叫a
的变量,而且把整数1
赋值给这个变量。若是咱们想查看这个变量的值的话,使用SELECT
语句就行了,不过仍然须要在变量名称加一个@
符号:bash
mysql> SELECT @a;
+------+
| @a |
+------+
| 1 |
+------+
1 row in set (0.00 sec)
mysql>
复制代码
同一个变量也能够存储存储不一样类型的值,比方说咱们再把一个字符串值赋值给变量a
:服务器
mysql> SET @a = '哈哈哈';
Query OK, 0 rows affected (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>
复制代码
这样变量a
和b
就有了相同的值'哇哈哈'
!学习
咱们还能够将某个查询的结果赋值给一个变量,前提是这个查询的结果只有一个值:优化
mysql> SET @a = (SELECT m1 FROM t1 LIMIT 1);
Query OK, 0 rows affected (0.00 sec)
mysql>
复制代码
还能够用另外一种形式的语句来将查询的结果赋值给一个变量:ui
mysql> SELECT n1 FROM t1 LIMIT 1 INTO @b;
Query OK, 1 row affected (0.00 sec)
mysql>
复制代码
由于语句SELECT m1 FROM t1 LIMIT 1
和SELECT n1 FROM t1 LIMIT 1
的查询结果都只有一个值,因此它们能够直接赋值给变量a
或者b
。咱们查看一下这两个变量的值:spa
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
中,m2
列的值赋值到了变量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> 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
客户端检测输入结束的符号,也包括多个字符,好比这样:
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》的连接 。小册的内容主要是从小白的角度出发,用比较通俗的语言讲解关于MySQL进阶的一些核心概念,好比记录、索引、页面、表空间、查询优化、事务和锁等,总共的字数大约是三四十万字,配有上百幅原创插图。主要是想下降普通程序员学习MySQL进阶的难度,让学习曲线更平滑一点~