窥探mysql存储过程细节
作者:迹忆 发布时间:2024-01-13 07:27:52
存储过程,可以这样认为,将我们需要特殊处理的sql语句封装成函数,当需要的时候我们只需调用这个函数就可以实现我们想要的操作,这个过程我们可以称之为存储过程。当然了,真正存储过程的定义不是这样的。但是我们可以这样简单的去理解存储过程。
下面我们看一个简单的使用存储过程的例子。
首先我们新建一张表 proced:
create table proced(
id int(5) primary key auto_increment,
name varchar(50),
type varchar(50)
);
然后我们需要向这个表中插入10万条数据,这个时候我们需要借助存储过程来实现这一功能。
mysql> delimiter //
mysql> create procedure adddata()
-->begin
-->declare n int default 0;
-->while n<100000
-->do
-->insert into proced(name,type) values(‘迹忆博客','onmpw');
-->set n = n+1;
-->end while;
-->end
-->//
mysql> delimiter ;
mysql> call adddata();
使用上述存储过程,我们就可以向proced表中插入10万条数据了。
借助上述小例子,我们来讲一下如何创建一个存储过程。
创建存储过程
首先我们来看一下创建存储过程的语法:
CREATE PROCEDURE procedure_name(IN/OUT/INOUT parameter TYPE)
BEGIN
procedure_body
END
这个过程比较简单。
在上面的小例子中我们看到在创建存储过程之前使用了delimiter //;,创建完成之后又再次 使用了命令 delimiter ;。
delimiter 是界定符,我们知道,在mysql命令行客户端,是通过分号(;)来界定一个命令是否完成的。在存储过程中,我们会多次使用到分号,但是这并不代表命令的结束,所以说我们需要使用delimiter命令来改变这个界定符。
mysql> delimiter //; 改变界定符为 //
mysql> delimiter ; 重新改变界定符为分号
所以说我们如果使用mysql命令行创建存储过程的话,我们必须在创建存储过程之前使用上述命令改变界定符。
接下来我们看到procedure_name()中的IN/OUT/INOUT,这是代表什么意思呢?
一个IN类型的参数会传递一个值到存储哦过程中,也就是我们在编程语言中自定义函数的参数。如果参数前面没有指定是IN/OUT/INOUT,那默认会是IN,看下面的例子:
mysql>delimiter //
mysql> create procedure in_proced(IN param VARCHAR(100))
-->begin
-->insert into proced(name,type) values(param,'onmpw');
-->end
-->//
mysql>delimiter ;
mysql> call in_proced(‘onmpw.com');
这就是在参数前指定IN的含义。
下面我们看OUT,指定为OUT的参数将从存储过程中传递一个值给调用者,也就是说,OUT可以认为这个参数就是我们自定义函数中的返回值。
mysql> delimiter //
mysql> create procedure out_proced(OUT param INT)
-->begin
-->select count(*) into param from proced;
-->end
-->//
mysql>delimiter ;
mysql> call out_proced(@a);
mysql>select @a;
+------+
| @a |
+------+
| 3 |
+------+
最后就是INOUT,很明显INOUT指定的参数被调用者初始化,其值在存储过程中可以被修改,并且任何改变对于调用者来说都是可见的。
看下面的例子:
mysql> delimiter //
mysql> create procedure inout_proced(INOUT param INT)
--> begin
--> select count(*) into param from proced where id>param;
--> end
-->//
mysql>delimiter ;
mysql>set @a = 3;
mysql>call inout_proced(@a);
mysql>select @a; 查看变量的值是否改变
删除存储过程
删除存储过程的语法:
DROP PROCEDURE IF EXISTS procedure_name
下面是使用实例:
mysql>drop procedure if exists proced;
修改存储过程
存储过程的修改时不能改变存储过程内的sql语句的,只能改变其属性,其语法如下:
ALTER PROCEDURE proc_name [characteristic ...]
characteristic:
COMMENT 'string'
| LANGUAGE SQL
| { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
| SQL SECURITY { DEFINER | INVOKER }
总结:无论是删除存储过程还是修改存储过程,必须保证你要修改或者删除存储过程没有被其他存储过程使用,例如你有存储过程A,和存储过程B。A在B中被使用,如果我们想修改A或者删除A,必须确保B中不再使用A,否则如果我们删除A以后,再调用B的时候就会报错。
举个例子:
mysql>delimiter //
mysql>create procedure A(IN pa1 INT,OUT pa2 INT)
-->begin
-->select count(*) into pa2 from proced where id>pa1;
-->end
-->//
mysql>create procedure B(INOUT pa INT)
-->begin
-->declare v int;
-->call A(pa,v);
-->set pa = v;
-->end
-->//
mysql>delimiter ;
mysql>drop procedure A;
mysql>set @a=5;
mysql>call B(@a);
ERROR 1305 (42000): PROCEDURE test.A does not exists


猜你喜欢
- 这几年比较火的一个漏洞就是jinjia2之类的模板引擎的注入,通过注入模板引擎的一些特定的指令格式,比如 {{1+1}} 而返回了 2 得知
- 由于工作关系,只能暂时放弃对mongodb的研究了 .开始研究PHPcms .目前为止我已经基本完成了模块的开发.趁着周末来这里做个总结.我
- 内容摘要:asp使用最多的就是ACCESS数据库和ms sql server数据库,本文列出了asp连接这两个数据库的方
- 首先mysql更新数据的某个字段,一般这样写:UPDATE mytable SET myfield = 'value' WH
- 代码实现的目的:为一个自定义的类的某个属性在使用它时候,触发某个事件。 该程序的效果:点击输入按钮,弹出一个脚本提示输入框让用户输入他的姓名
- 平行坐标图,一种数据可视化的方式。以多个垂直平行的坐标轴表示多个维度,以维度上的刻度表示在该属性上对应值,相连而得的一个折线表示一个样本,以
- 1969年8月8日,在北京协和医院降生了一个漂亮的小女孩。接生的阿姨说,她的声音这么大,好象想要全世界的人都听到。后来,她的父亲为她取了一个
- logging模块是Python内置的标准模块,主要用于输出运行日志,可以设置输出日志的等级、日志保存路径、日志文件回滚等。其主
- 创建一个示例数据框:import pandas as pddf = pd.DataFrame([['乔峰', '男&
- 请问鼠标移过去就出现二级菜单代码怎么写啊 <head><style type="tex
- Windows中升级MySQL应采取的步骤:1. 进行升级前你应先备份当前的MySQL安装。2. 下载最新Windows版MySQL。3.
- 首先去官网下载两个架包链接如下:官网链接第一步:将两个架包解压到同一个database目录下。如截图所示:第二步:打开setup应用程序打开
- 相比于逻辑回归,在很多情况下,SVM算法能够对数据计算从而产生更好的精度。而传统的SVM只能适用于二分类操作,不过却可以通过核技巧(核函数)
- 本文实例讲述了Python实现的端口扫描功能。分享给大家供大家参考,具体如下:一 代码import sysimport socketimpo
- php 运算符与表达式一、运算符的分类1、按操作数分类1.!true // 一元运算符2.$a+$b // 二元运算符3.true ? 1:
- 本文实例讲述了微信小程序学习笔记之本地数据缓存功能。分享给大家供大家参考,具体如下:前面介绍了微信小程序获取位置信息操作。这里再来介绍一下微
- 前言近端时间看了一个短视频,觉得视频的背景音乐片段很不错,想把这个背景音乐得到,虽然小编运用Python爬虫肯定能得到这首音乐,但是这个音乐
- 项目中我们可能会碰到导出Excel文件的需求,一般后台管理系统中居多,将table中展示的数据导出保存到本地。当然我们也可以通过一些处理来修
- 本文实例讲述了golang实现unicode转换为字符串string的方法。分享给大家供大家参考,具体如下:package mainimpo
- 1、返回json响应结果在struct的字段后面加入json:"key"可以进行json格式输出,其中key为json的