Mysql存储过程学习笔记--建立简单的存储过程
作者:hebedich 发布时间:2024-01-23 14:41:21
一、存储过程
存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户
通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。而我们常用的操作数据库语言SQL语句在执行的时
候需要要先编译,然后执行,所以执行的效率没有存储过程高。
存储过程优点如下:
重复使用。存储过程可以重复使用,从而可以减少数据库开发人员的工作量。提高性能。存储过程在创建的时候在进行了编译,将来使用的时候不再重新翻译。一般的SQL语句每执行一次就需要编译一次,所以使用存储过程提高了效率。减少网络流量。存储过程位于服务器上,调用的时候只需要传递存储过程的名称以及参数就可以了,因此降低了网络传输的数据量。安全性。参数化的存储过程可以防止SQL注入式攻击,而且可以将Grant、Deny以及Revoke权限应用于存储过程。
存储过程简单语法:
CREATE PROCEDURE 存储过程名称(
输入输出类型 变量名称 类型,
输入输出类型 变量名称 类型
)
BEGIN
-- 声明, 语句要完成的操作,增删改查。。。
END
二、实例
例子中的存储过程均使用mysql作为例子。
表结构如下:
DROP TABLE IF EXISTS `person`;
CREATE TABLE `person` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(255) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`password` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;
1、只带IN(输入参数)的存储过程
表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值.
DROP PROCEDURE IF EXISTS proc_person_findById;
-- 创建存储过程
CREATE PROCEDURE proc_person_findById(
in n int
)
BEGIN
SELECT * FROM person where id=n;
END
-- 定义变量
SET @n=2;
-- 调用存储过程
CALL proc_person_findById(@n);
调用结果如下:
2、只带OUT(输出参数)的存储过程
该值可在存储过程内部被改变,并可返回。
DROP PROCEDURE IF EXISTS proc_person_getCount
-- 创建存储过程
CREATE PROCEDURE proc_person_getCount(
out n int(11)
)
BEGIN
SELECT COUNT(*) INTO n FROM person ;
END
-- 调用存储过程
CALL proc_person_getCount(@n);
SELECT @n as '总数';
调用结果如下:
3、带IN(输入参数)和OUT(输出参数)的
调用时指定,并且可被改变和返回
DROP PROCEDURE IF EXISTS proc_person_findInfoById;
-- 创建存储过程
CREATE PROCEDURE proc_person_findInfoById(
IN n INT(11),
OUT pusername VARCHAR(255),
OUT page INT(11)
)
BEGIN
SELECT username, age INTO pusername, page FROM person WHERE id=n;
END
-- 定义变量
SET @id=2;
-- 调用存储过程
CALL proc_person_findInfoById(@id,@username, @age);
SELECT @username as '用户名', @age '年龄';
调用结果如下:
4、带INOUT(输入输出)参数的存储过程
-- 输入输出DROP PROCEDURE IF EXISTS proc_person_get_age;-- 创建存储过程CREATE PROCEDURE proc_person_get_age( INOUT n INT(11))BEGIN SELECT age INTO N FROM person WHERE id=n;ENDSET @id = 1;CALL proc_person_get_age(@id); SELECT @id;
调用结果如下:
5、 关于输入输出参数
IN为输入, 定义参数时,可以不加,不加则默认为输入参数。OUT为输出,定义参数时,必须加上。INOUT为输入和输出,必须加上。表示该参数可以输入也可在处理后存放结果进行输出。
猜你喜欢
- 一、安装redis:1.下载:wget http://download.redis.io/releases/redis-3.2.8.tar.
- 本文实例总结了Python字典常见操作。分享给大家供大家参考,具体如下:简单的字典:字典就是键值对key-value组合。#字典 键值对组合
- 效果图最近帮朋友写个简单爬虫,顺便整理了下,搞成了一个带GUI界面的小说爬虫工具,用来从笔趣阁爬取小说。开发完成后的界面采集过程界面采集后存
- Python程序可以调用一组基本的函数(即内建函数),比如print()、input()和len()等函数。Python本身也内置一组模块(
- 一、*args的使用方法*args 用来将参数打包成tuple给函数体调用def fun(*arg): print(arg,ty
- 1 输出大写字母、小写字母、大小写字母、数字、大小写字母和数字1.1输出小写:找到小写a(97)到z(122)的的ASCII码,然后转义为字
- 本文实例讲述了Python排序搜索基本算法之选择排序。分享给大家供大家参考,具体如下:选择排序就是第n次把序列中最小的元素排在第n的位置上,
- 一个简单但功能比较完善的自动生成缩略图的函数,可以按需要对图片进行缩放、裁切、锁定宽或高、使用空白填充以下为源码,比较简单,相信很容易看明白
- 前言Django提供了多种装饰器, 其中login_required可能是经常会使用到的。 这里介绍下四种使用此装饰器的办法。当然, 在使用
- Django2.0中编写models类下的ForeignKeybook = models.ForeignKey('BookInfo&
- 本文实例为大家分享了python创建tcp服务端和客户端的具体代码,供大家参考,具体内容如下1.服务端serverfrom socket i
- 问题你的程序中有个方法会输出到标准输出中(sys.stdout)。也就是说它会将文本打印到屏幕上面。 你想写个测试来证明它,给定一个输入,相
- 前言本篇文章主要讲述了Mac下Redis的安装和使用的经验,并将python如何操作Redis做了简单介绍。1. redis 安装 和启动1
- 前言每次开发滑块控件的样式都要花很久去读样式代码,感觉有点记不牢,所以特此备忘。自定义滑块样式首先创建项目,添加Slider控件。然后获取S
- 本文实例讲述了python实现马耳可夫链算法的方法。分享给大家供大家参考。具体分析如下:在《程序设计实践》(英文名《The Practice
- IFRAME 元素 | iframe 对象创建内嵌浮动框架。成员表下面的表格列出了 iframe 对象引出的成员。请单击左侧的标签来选择你想
- 本文实例讲述了php测试kafka项目。分享给大家供大家参考,具体如下:概述Kafka是最初由Linkedin公司开发,是一个分布式、分区的
- Dreamweaver(以下简称DW)提供了一种称为“Behavior”(行为)的机制,帮助你构建页面
- TTS简介TTS(Text To Speech)是一种语音合成技术,可以让机器将输入文本以语音的方式播放出来,实现机器说话的效果。TTS分成
- 一、TensorFlow常规模型加载方法保存模型tf.train.Saver()类,.save(sess, ckpt文件目录)方法参数名称功