• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > Mysql存储过程学习笔记--建立简单的存储过程

Mysql存储过程学习笔记--建立简单的存储过程

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了Mysql存储过程学习笔记--建立简单的存储过程等相关知识,希望本文的分享对您有所帮助

一、存储过程

  存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户
通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。而我们常用的操作数据库语言SQL语句在执行的时
候需要要先编译,然后执行,所以执行的效率没有存储过程高。

  存储过程优点如下:

重复使用。存储过程可以重复使用,从而可以减少数据库开发人员的工作量。提高性能。存储过程在创建的时候在进行了编译,将来使用的时候不再重新翻译。一般的SQL语句每执行一次就需要编译一次,所以使用存储过程提高了效率。减少网络流量。存储过程位于服务器上,调用的时候只需要传递存储过程的名称以及参数就可以了,因此降低了网络传输的数据量。安全性。参数化的存储过程可以防止SQL注入式攻击,而且可以将Grant、Deny以及Revoke权限应用于存储过程。

  存储过程简单语法:

CREATE PROCEDURE 存储过程名称(
  输入输出类型 变量名称 类型,

    输入输出类型 变量名称 类型

)
BEGIN
  -- 声明, 语句要完成的操作,增删改查。。。
END

</div>

二、实例

  例子中的存储过程均使用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为输入和输出,必须加上。表示该参数可以输入也可在处理后存放结果进行输出。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2017-05-11MySQL 实现双向复制的方法指南
  • 2018-12-05SQL 外链接操作小结 inner join left join right join
  • 2018-12-05Mysql之库表操作的实例代码
  • 2018-12-05Oracle 外连接实现代码
  • 2018-12-05mysql 无限级分类实现思路
  • 2018-12-05mysqlslap执行基准测试的代码详情介绍
  • 2017-05-11mysql 5.0.45 (修改)拒绝服务漏洞
  • 2017-05-11从MySQL复制功能中得到的一举三得实惠分析
  • 2017-05-11MySQL 加密/压缩函数
  • 2018-12-05MySQL入门书籍和方法分享

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • SqlServer 基础知识 数据检索、查询排序语句
    • Mysql系列(九) 单引号与反引号
    • linux下mysql自动备份脚本代码
    • SQL Server 2005 DTS导入平面数据出现错误解决方案
    • 自己收集比较强大的分页存储过程 推荐
    • 深入sql多表差异化联合查询的问题详解
    • C++ ADO操作mysql数据库
    • 详解MySQL下InnoDB引擎中的Memcached插件
    • MySql5.7.12免安装版配置以及服务无法启动问题解决方法_MySQL
    • sqlserver 存储过程中的top+变量使用分析(downmoon)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有