博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mysql存储过程
阅读量:6295 次
发布时间:2019-06-22

本文共 3656 字,大约阅读时间需要 12 分钟。

1、什么是存储过程?

   我们操作的SQL语句在每次执行的时候需要先编译,再执行;而存储过程(Stroed Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中(有点类似于Java的static变量)。

   在我们需要使用的时候通过指定存储过程的名字并指定参数(如果该存储过程带有参数)来调用执行它。

   一个存储过程是一个可编程的函数,它在数据库中创建被保存,由SQL语句和一些特殊的控制结构语句组成。

2、存储过程的优点有哪些?

  (1)增强SQL语言的功能和灵活性

    存储过程可以使用流控制语句(IF...ELSE...),有很强的灵活性,可以完成复杂的判断和运算。

  (2)提升执行速度

    如果某一操作包含大量的Transaction-SQL代码或分别被多次执行,那么存储过程要比批处理的执行速度要快很多。因为存储过程是预编译的,在首次运行一个存储过程时,优化器对其进行分析优化,最终存储下来,不必每次都进行编译。

  (3)减少网络流量

    针对同一个数据库对象的操作(如查询、修改),Transaction-SQL语句可能比调用存储过程语句要复杂,所以使用存储过程降低了网络负载和网络流量。

  (4)保证安全

    系统管理员通过执行某一存储过程的权限进行限制,能够实现对相应的数据的访问权限的限制,避免了非授权用户对数据的访问,保证了数据的安全。

3、MySQL的存储过程

  存储过程是数据库存储的一个重要的功能,但是MySQL在5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣。好在MySQL 5.0终于开始已经支持存储过程,这样即可以大大提高数据库的处理速度,同时也可以提高数据库编程的灵活性。

4、准备数据

DROP TABLE IF EXISTS `t_user`;CREATE TABLE `t_user` (  `ID` int(11) NOT NULL,  `USERNAME` varchar(16) NOT NULL,  `CITY` varchar(10) CHARACTER SET utf8 DEFAULT NULL,  `PHONE` varchar(10) DEFAULT NULL,  PRIMARY KEY (`ID`),  UNIQUE KEY `name_city_phone` (`USERNAME`,`CITY`,`PHONE`),  KEY `U_INDEX` (`USERNAME`)) ENGINE=InnoDB DEFAULT CHARSET=latin1;-- ------------------------------ Records of t_user-- ----------------------------INSERT INTO `t_user` VALUES ('4', 'Jack', '深圳', '185');INSERT INTO `t_user` VALUES ('3', 'Jerry', '北京', '181');INSERT INTO `t_user` VALUES ('1', 'parry', '广州', '180');INSERT INTO `t_user` VALUES ('2', 'Tom', '上海', '189');

5、Mysql存储过程

  (1)创建存储过程

CREATE PROCEDURE P_NAME()BEGIN    ......END

  (2)调用存储过程

CALL P_NAME() // 存储过程名称(P_NAME)后面必须添加括号,即使没有参数

  (3)删除存储过程

DROP PROCEDURE P_NAME; //不能在一个存储过程中删除另一个存储古城,只能调用另一个存储过程

  (4)查看数据库里全部的存储过程

SHOW PROCEDURE STATUS

  (5)查看单个存储过程的详细信息

SHOW CREATE PROCEDURE P_NAME

6、创建存储过程详解

  (1)简单的无参存储过程(查询所有的结果集)

DROP PROCEDURE IF EXISTS P_user;CREATE PROCEDURE P_user()BEGIN    SELECT * FROM t_user;END;

  调用:CALL P_user();

  

  (2)带参存储过程

    MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT,形式如:

    CREATE PROCEDURE([[IN |OUT |INOUT ] 参数名 数据类形...])

    a.IN参数

/*创建存储过程*/DROP PROCEDURE IF EXISTS P_user;CREATE PROCEDURE P_user(IN t_id VARCHAR(10))BEGIN        SELECT * FROM t_user WHERE ID = t_id;END;/*调用存储过程*/CALL P_user(1);
View Code

      

    b.OUT参数

/*创建存储过程*/DROP PROCEDURE IF EXISTS P_user;CREATE PROCEDURE P_user(IN t_id VARCHAR(10),OUT uCount INT)BEGIN        SELECT COUNT(*) FROM t_user WHERE ID = t_id;END;/*调用存储过程*/CALL P_user(4,@p_num);SLEEP(@p_num)
View Code

    

    c.INOUT参数(参数是入参也是出参)

/*创建存储过程*/DROP PROCEDURE IF EXISTS P_user;CREATE PROCEDURE P_user(INOUT t_id VARCHAR(10))BEGIN        SELECT COUNT(*) FROM t_user WHERE ID = t_id;END;/*调用存储过程*/SET @p_num = 4;CALL P_user(@p_num);SELECT @p_num;
View Code

    

  (3)流程控制语句(如果ID被2整除,查询1,3;否则查询2,4)

    IF...THEN

    ELSEIF ...THEN

    ELSE...

    END IF

/*创建存储过程*/DROP PROCEDURE IF EXISTS P_user;CREATE PROCEDURE P_user(IN t_id VARCHAR(10))BEGIN    IF t_id%2 = 0 THEN        SELECT * FROM t_user WHERE ID IN(2,4);    ELSE        SELECT * FROM t_user WHERE ID IN(1,3);    END IF;END;/*调用存储过程*/SET @p_num=1;CALL P_user(@p_num);
View Code

      

  (4)while语句

    while ... do

      ......

    end while;

/*创建存储过程*/DROP PROCEDURE IF EXISTS P_user;CREATE PROCEDURE P_user()BEGIN    DECLARE temp INT;    SET temp = 1;    WHILE temp<5 DO        SELECT * FROM t_user WHERE ID = temp;        SET temp = temp + 1;    END WHILE;END;/*调用存储过程*/CALL P_user();
View Code

    

   (5)repeat语句

      repeat...

      until ...

      end repeat;

DROP PROCEDURE IF EXISTS P_user;CREATE PROCEDURE P_user()BEGIN    DECLARE temp INT;    SET temp = 1;    REPEAT        SELECT * FROM t_user WHERE ID = temp;        SET temp = temp + 1;    UNTIL temp>=5    END REPEAT;END;/*调用存储过程*/CALL P_user();
View Code

    

转载地址:http://wkvta.baihongyu.com/

你可能感兴趣的文章
Android SharedPreferences
查看>>
css面试题
查看>>
Vue组建通信
查看>>
用CSS画一个带阴影的三角形
查看>>
前端Vue:函数式组件
查看>>
程鑫峰:1.26特朗.普力挺美元力挽狂澜,伦敦金行情分析
查看>>
safari下video标签无法播放视频的问题
查看>>
01 iOS中UISearchBar 如何更改背景颜色,如何去掉两条黑线
查看>>
对象的继承及对象相关内容探究
查看>>
Spring: IOC容器的实现
查看>>
Serverless五大优势,成本和规模不是最重要的,这点才是
查看>>
Nginx 极简入门教程!
查看>>
iOS BLE 开发小记[4] 如何实现 CoreBluetooth 后台运行模式
查看>>
Item 23 不要在代码中使用新的原生态类型(raw type)
查看>>
为网页添加留言功能
查看>>
JavaScript—数组(17)
查看>>
Android 密钥保护和 C/S 网络传输安全理论指南
查看>>
以太坊ERC20代币合约优化版
查看>>
Why I Began
查看>>
同一台电脑上Windows 7和Ubuntu 14.04的CPU温度和GPU温度对比
查看>>