mysql存储过程讲解
1.数据库存储过程:简单滴说,存储过程就是存储在数据库中的一个程序。
2..数据库存储过程作用:
第一:存储过程因为SQL语句已经预编绎过了,因此运行的速度比较快。
- 第二:存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值。可以向程序返回错误原因。
- 第三:存储过程运行比较稳定,不会有太多的错误。只要一次成功,以后都会按这个程序运行。
- 第四:存储过程主要是在服务器上运行,减少对客户机的压力。
- 第五:存储过程可以包含程序流、逻辑以及对数据库的查询。同时可以实体封装和隐藏了数据逻辑。
- 第六:存储过程可以在单个存储过程中执行一系列 SQL 语句。
- 第七:存储过程可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。
- 此外,如果多条SQL语句执行过程中,过程环节返回了数据作为后面环节的输入数据,如果直接通过
- SQL语句执行,势必导致大量的数据通过网络返回到客户机,并在客户机运算;如果封装在存储过程中,
- 则将运算放在服务器进行,不但减少了客户机的压力,同时也减少了网络流量,提高了执行的效率。
3.mysql存储过程:
MySQL5存储过程,用得人好像不多。按照数据库设计原理来讲,存储过程是在db server上预编译的,所以查询速度会比较起纯SQL语句快很多。可能是现在流行OO,导至存储过程使用的余地大打折扣。但如果从效果上来讲,用存储过程来实现业务规则所带得DB SERVER压力,比用JAVA类实现业务规则所带来的WEB SERVER压力要小。当然存储过程也不应滥用,象普通的insert、update之类的语句就不需要使用存储过程了。
好了,言归正传。MySQL创建procudure的语法与sql server/Oracle差别较大。
例1:传入参数的procedure
create procedure usp_test(param varchar(20) select * from talbeName where column=param |
例2:更新表的procedure
create procedure usp_test2 (t varchar(20)) begin set xname = 'test'; update table set column = xname where column1=t; end |
MySQL创建存储过程时不带as,而且()不能省略,即便是没有传入参数。这一点象sql server或是oracle那样直观,而且声明变量时直接用declare,不用加的@或@@(in out变量除外)。还有一点是很怪的语法,如果是以“select”为开头的存储过程,是不能加"begin end"的。"begin end"表示多条SQL语句的复合体。
当然,事实上几乎没有哪款数据库是完全符合SQL3标准的,多少都含有自己的一些成份里面,这也造成使用存储过程会使程序的可移性降低。
调用procedure
MySQL使用call关键字。例:call usp_test('test');而不是execute,同样()是不能省略的。
创建完procedure后,再看看java是如何调用procedure的。
Connection conn = null;
- CallableStatement cstmt = null;
- ResultSet rs = null;
- try{
- conn = DbConn.getDbConn();//get pool conn
- CallableStatement cstmt = conn.prepareCall("{call usp_test(?)}");
- call.setString(1, "test");
- rs = call.executeQuery();
- while(rs.next()){
- String te = rs.getString(1);
- System.out.println("te:"+te);
- }
- }catch(Exception e){
- System.out.println("e: "+e);
- }finally{
- try{
- rs.close();
- cstmt.close();
- conn.close();
- }catch(Exception ex){
- System.out.println("ex:"+ex);
- }
- }
这里使用的是"{call usp_test()}"来调用存储过程。同时也可以编程传入参数,进行查询。
上述方法有个致命的缺点,就是传入的参数是由编写存储过程决定的。也就是说不支持象PreparedStatement那样的多参数动态查询。
下面先讲解MySQL存储过程的输入输出参数应用。例子可以直接copy运行。
1.输入参数(也是默认参数)
CREATE PROCEDURE usp1(IN p INT)
BEGIN
SET @x = p;
END;
call usp1(123456);
select @x
返回结果为 123456
2.输出参数(out)
CREATE PROCEDURE usp2 (OUT p int, IN p2 int)
BEGIN
SET p = -5 + p2;
END
call p6(@y,10)
select @y
返回结果为 5
3.输入输出参数(inout)
CREATE PROCEDURE demoSp(IN inputParam VARCHAR(255), INOUT inOutParam INT) BEGIN SET inOutParam = 1000; SELECT inOutParam; SELECT CONCAT('zyxw ', inputParam); END |
call demoSP(' test',@q)
返回结果"zyxw test"。
MySQL调用存储过程的语法讲完了,总结一下就是三个参数关键值IN、OUT、INOUT,分别代表输入参数、输出参数、输入输出参数。下面就讲解是JAVA是如何调用带有输出参数的存储过程。
先创建一个带输出参数的Procedure
CREATE PROCEDURE demoSp(OUT inOutParam varchar(50)) BEGIN set inOutParam = "hello procedure"; END |
然后在java中调用。
CallableStatement cstmt = conn.prepareCall("{call demoSp(?)}"); cstmt.registerOutParameter(1, java.sql.Types.VARCHAR); boolean i = cstmt.execute();
String x = cstmt.getString(1); |
很明显与没有输出参数的存储过程相比,多一个registerOutParameter。
也就是说要先注册输出参数的类型,再执行execute(),最后取回车出参数的值。
这个过程是不能颠倒的。
mysql存储过程讲解的更多相关文章
- 转载:mysql存储过程讲解
记录MYSQL存储过程中的关键语法: DELIMITER // 声明语句结束符,用于区分; CEATE PROCEDURE demo_in_parameter(IN p_in int) 声明存储过程 ...
- mysql存储过程详细讲解及完整实例下载
一.存储过程概念 1.存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集.经编译后存储在数据库 中. 2.存储过程是数据库中的一个重要对象,用户通过指定存储过程的名字并给 ...
- mysql存储过程详解
mysql存储过程详解 1. 存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的S ...
- mysql存储过程详细教程
记录mysql存储过程中的关键语法:DELIMITER // 声明语句结束符,用于区分;CREATE PROCEDURE demo_in_parameter(IN p_in int) 声明存储过程 ...
- Mysql存储过程总结
1. 关于MySQL的存储过程 存储过程是数据库存储的一个重要的功能,但是MySQL在5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣.好在MySQL 5.0终于开始已经支持存储过 ...
- mysql 存储过程详解 存储过程
mysql存储过程详解 1. 存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成 ...
- MySQL存储过程详解 mysql 存储过程
原文地址:MySQL存储过程详解 mysql 存储过程作者:王者佳暮 mysql存储过程详解 1. 存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储 ...
- MySQL存储过程详解 mysql 存储过程(二)
mysql存储过程详解 1. 存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL ...
- mysql存储过程详解[转]
1. 存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储 ...
随机推荐
- 使用日志服务LogHub替换Kafka
https://yq.aliyun.com/articles/35979#index_section
- 在javascript中关于submit和button提交表单区别
submit是button的一个特例,也是button的一种,它把提交这个动作自动集成了,submit和button,二者都以按钮的形式展现,看起来都是按钮,所不同的是type属性和处发响应的事件上. ...
- js父窗口opener与parent
parent表示父窗口,比如一个A页面利用iframe或frame调用B页面,那么A页面所在窗口就是B页面的parent.在JS 中,window.opener只是对弹出窗口的母窗口的一个引用.比如: ...
- uiautomator日志文件转换为xml格式文件
如果想把uiautomator的日志文件,转换成漂亮的xml文件,那么可以使用automator-log-converter.jar工具, 工具使用方法: 使用工具automator-log-conv ...
- casperjs 抓取爱奇艺高清视频
CasperJS 是一个开源的导航脚本和测试工具,使用 JavaScript 基于 PhantomJS 编写,用于测试 Web 应用功能,Phantom JS是一个服务器端的 JavaScript A ...
- 重大发现Android studio 如何简单快速修改package name
好多人都发现Android studio修改包名比较麻烦,只能一级一级的修改,今天偶尔发现了一个快捷方法. 废话不多说: 1 打开项目的AndroidManifest.xml文件 2 鼠标光笔定位到你 ...
- Sqlserver基于流程控制
流程控制语句只能在单个批处理段,用户自定义函数和存储过程中使用不能夸多个批处理或者用户自定义函数或者存储过程 批处理:一个或者多个语句组成的一个批处理,是因为所有语句一次性地被提交到一个sql实例,如 ...
- phpize php扩展模块安装
安装(fastcgi模式)的时候,常常有这样一句命令:/usr/local/webserver/php/bin/phpize一.phpize是干嘛的?phpize是什么东西呢?php官方的说明:htt ...
- Install GTK in Ubuntu
reference: http://www.cnblogs.com/niocai/archive/2011/07/15/2107472.html 一.安装 1.安装gcc/g++/gdb/make 等 ...
- 鼠标点击input时,placeholder中的提示信息消失
html代码: <input type="text" placeholder="多个关键词空格隔开"> 鼠标点击input时,placeholder ...