java调用mysql存储过程

1.数据库存储过程:简单滴说,存储过程就是存储在数据库中的一个程序。

2..数据库存储过程作用:  

Html代码
  1. 第一:存储过程因为SQL语句已经预编绎过了,因此运行的速度比较快。
  2. 第二:存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值。可以向程序返回错误原因。      
  3. 第三:存储过程运行比较稳定,不会有太多的错误。只要一次成功,以后都会按这个程序运行。      
  4. 第四:存储过程主要是在服务器上运行,减少对客户机的压力。    
  5. 第五:存储过程可以包含程序流、逻辑以及对数据库的查询。同时可以实体封装和隐藏了数据逻辑。    
  6. 第六:存储过程可以在单个存储过程中执行一系列   SQL   语句。    
  7. 第七:存储过程可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。 
  8. 此外,如果多条SQL语句执行过程中,过程环节返回了数据作为后面环节的输入数据,如果直接通过 
  9. SQL语句执行,势必导致大量的数据通过网络返回到客户机,并在客户机运算;如果封装在存储过程中, 
  10. 则将运算放在服务器进行,不但减少了客户机的压力,同时也减少了网络流量,提高了执行的效率。 
第二:存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值。可以向程序返回错误原因。     
第三:存储过程运行比较稳定,不会有太多的错误。只要一次成功,以后都会按这个程序运行。     
第四:存储过程主要是在服务器上运行,减少对客户机的压力。   
第五:存储过程可以包含程序流、逻辑以及对数据库的查询。同时可以实体封装和隐藏了数据逻辑。   
第六:存储过程可以在单个存储过程中执行一系列   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;

Java代码
  1. CallableStatement cstmt = null
  2. ResultSet rs = null
  3. try
  4.     conn = DbConn.getDbConn();//get pool conn 
  5.     CallableStatement cstmt = conn.prepareCall("{call usp_test(?)}"); 
  6.         call.setString(1, "test"); 
  7.         rs = call.executeQuery(); 
  8.         while(rs.next()){ 
  9.             String te = rs.getString(1); 
  10.             System.out.println("te:"+te); 
  11.         } 
  12.     }catch(Exception e){ 
  13.         System.out.println("e: "+e); 
  14.     }finally
  15.         try
  16.             rs.close(); 
  17.             cstmt.close(); 
  18.             conn.close(); 
  19.         }catch(Exception ex){ 
  20.             System.out.println("ex:"+ex); 
  21.         } 
  22.     } 
    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)
返回结果"zyxwtest"。

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);
            System.out.println("call result:"+i+x);


很明显与没有输出参数的存储过程相比,多一个registerOutParameter。
也就是说要先注册输出参数的类型,再执行execute(),最后取回车出参数的值。
这个过程是不能颠倒的。

### 什么是云计算 云计算是种基于互联网的计算模式,它允许用户通过网络按需访问共享资源池(如服务器、存储、应用程序和服务),而无需拥有这些物理资产。这种模式显著降低了企业的资本支出和技术门槛,同时提高了灵活性和可扩展性[^1]。 ### 软件定义网络 (SDN) 技术概述 #### 定义与核心理念 软件定义网络(Software Defined Networking, SDN)是种新型的网络架构设计方法。它的主要特点是将网络设备中的控制平面与数据转发平面分离,从而使网络管理员可以通过集中式的控制器对整个网络进行管理。这设计理念不仅提升了网络流量调度的灵活性,还增强了网络智能化水平[^2]。 #### 组成部分 SDN 架构通常由三个层次构成:应用层、控制层以及基础设施层。 - **应用层**负责提供各种业务功能,例如负载均衡器、防火墙等服务; - **控制层**作为桥梁连接上下两层结构,其中心角色是由个逻辑上的单实体——SDN 控制器扮演,该组件接收来自上层的应用请求并将其转化为具体指令下发给底层硬件执行; - **基础设施层**则包含了实际完成包转发任务的各种交换机路由器等物理或虚拟化的网络单元[^1]。 #### 发展背景及其意义 为了应对日益复杂的现代通信需求所带来的挑战,比如带宽消耗激增、服务质量保障困难等问题,传统的封闭式专有协议驱动型网络逐渐暴露出诸不足之处。因此出现了向更开放标准化方向演进的趋势,在此背景下诞生了SDN这项革命性的技术创新成果。借助于支持种南向接口协议(OpenFlow是最具代表性的例子之),再加上北向API所提供的强大编程能力,使得开发者可以轻松创建定制化解决方案以满足特定场景下的特殊要求[^3]。 ```python # 示例代码展示如何模拟简单的SDN环境设置过程 from mininet.net import Mininet from mininet.node import Controller, RemoteController, OVSKernelSwitch def create_network(): net = Mininet(controller=RemoteController, switch=OVSKernelSwitch) c0 = net.addController('c0', controller=RemoteController, ip='127.0.0.1', port=6653) s1 = net.addSwitch('s1') h1 = net.addHost('h1') h2 = net.addHost('h2') net.addLink(h1, s1) net.addLink(s1, h2) net.start() print("Network started.") net.stop() create_network() ``` ### 云计算与SDN的关系 两者之间存在紧密联系又各有侧重领域。方面,得益于后者提供的动态调整能力和自动化运维手段的支持,前者得以构建起弹性伸缩性强且成本效益高的数据中心运营体系;另方面,当把目光投射到广域范围内的互联组网上时,则更依赖前者的全局视角优势来进行跨地域资源整合调配工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值