`
suchj
  • 浏览: 146343 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

java 调用 mysql存储过程实例(转)

    博客分类:
  • java
阅读更多
这是我学习MySQL存储过程中找到的,为了以后别忘了,留念一下
原文地址:http://dev.firnow.com/course/3_program/java/javajs/200896/139314.html

import java.sql.*;
 
/**
iGoder
*/
public class ProcedureTest {
/*
表和存储过程定义如下:
delimiter //
 
DROP TABLE if exists test //
    CREATE TABLE test(
      id int(11) NULL
    ) //

drop procedure if exists sp1 //
   
    create procedure sp1(in p int)
    comment 'insert into a int value'
    begin
      declare v1 int;
      set v1 = p;
      insert into test(id) values(v1);
    end
    //
   
    drop procedure if exists sp2 //
    create procedure sp2(out p int)
    begin
      select max(id) into p from test;
    end
    //
    
drop procedure if exists sp6 //
    create procedure sp6()
    begin
       select * from test;
    end//
   
*/
 
public static void main(String[] args) {
  //callIn(111);
  //callOut();
  callResult();
}
 
/**
  * 调用带有输入参数的存储过程
  * @param in     stored procedure input parameter value
  */
public static void callIn(int in){
  //获取连接
  Connection conn = ConnectDb.getConnection();
  CallableStatement cs = null;
  try {
   //可以直接传入参数
   //cs = conn.prepareCall("{call sp1(1)}");
  
   //也可以用问号代替
   cs = conn.prepareCall("{call sp1(?)}");
   //设置第一个输入参数的值为110
   cs.setInt(1, in);
  
   cs.execute();
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   try {
    if(cs != null){
     cs.close();
    }
    if(conn != null){
     conn.close();
    }
   } catch (Exception ex) {
    ex.printStackTrace();
   }
  }
 
}

/**
  * 调用带有输出参数的存储过程
  *
  */
public static void callOut() {
  Connection conn = ConnectDb.getConnection();
  CallableStatement cs = null;
  try {
   cs = conn.prepareCall("{call sp2(?)}");
   //第一个参数的类型为Int
   cs.registerOutParameter(1, Types.INTEGER);
   cs.execute();
  
   //得到第一个值
   int i = cs.getInt(1);
   System.out.println(i);
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   try {
    if(cs != null){
     cs.close();
    }
    if(conn != null){
     conn.close();
    }
   } catch (Exception ex) {
    ex.printStackTrace();
   }
  }
}

/**
  * 调用输出结果集的存储过程
  */
public static void callResult(){
  Connection conn = ConnectDb.getConnection();
  CallableStatement cs = null;
  ResultSet rs =  null;
  try {
   cs = conn.prepareCall("{call sp6()}");
   rs = cs.executeQuery();
  
   //循环输出结果
   while(rs.next()){
    System.out.println(rs.getString(1));
   }
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   try {
    if(rs != null){
     rs.close();
    }
    if(cs != null){
     cs.close();
    }
    if(conn != null){
     conn.close();
    }
   } catch (Exception ex) {
    ex.printStackTrace();
   }
  }
}

}
 
 
/**
*获取数据库连接的类
*/

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
 
class ConnectDb {

public static Connection getConnection(){
  Connection conn = null;
  PreparedStatement preparedstatement = null;
  try {
   Class.forName("org.gjt.mm.mysql.Driver").newInstance();
   String dbname = "test";
   String url ="jdbc:mysql://localhost/"+dbname+"?user=root&password=root&useUnicode=true&characterEncoding=8859_1" ;
   conn= DriverManager.getConnection(url);
  } catch (Exception e) {
   e.printStackTrace();
  }
  return conn;
}
 
}
分享到:
评论

相关推荐

    java 调用 mysql存储过程实例

    java 调用 mysql存储过程实例

    java调用mysql存储过程实例分析

    主要介绍了java调用mysql存储过程的方法,以实例形式较为详细的分析了mysql数据库的建立和存储过程的实现方法,需要的朋友可以参考下

    Java调用MySQL存储过程并获得返回值的方法

    主要介绍了Java调用MySQL存储过程并获得返回值的方法,实例分析了java实现MySQL存储过程的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下

    mysql存储过程和存储函数的示例

    mysql 存储过程 ,存储函数的调用示例

    java源码包---java 源码 大量 实例

    摘要:Java源码,初学实例,EJB调用实例  各种EJB之间的调用源码示例,用远程接口的引用访问EJB、函数将被FirstEJB调用,同时它将调用secondEJB 基于JAVA的UDP服务器模型源代码 2个目标文件 摘要:Java源码,网络相关,...

    JAVA上百实例源码以及开源项目源代码

    摘要:Java源码,初学实例,EJB调用实例  各种EJB之间的调用源码示例,用远程接口的引用访问EJB、函数将被FirstEJB调用,同时它将调用secondEJB 基于JAVA的UDP服务器模型源代码 2个目标文件 摘要:Java源码,网络相关,...

    JAVA上百实例源码以及开源项目

    摘要:Java源码,初学实例,EJB调用实例  各种EJB之间的调用源码示例,用远程接口的引用访问EJB、函数将被FirstEJB调用,同时它将调用secondEJB 基于JAVA的UDP服务器模型源代码 2个目标文件 摘要:Java源码,网络相关,...

    mysql存储过程用法实例分析

    本文实例讲述了mysql存储过程用法。分享给大家供大家参考,具体如下: 概述: 简单的说,就是一组SQL语句集,功能强大,可以实现一些比较复杂的逻辑功能,类似于JAVA语言中的方法; 存储过程跟触发器有点类似,都是...

    JAVA 范例大全 光盘 资源

    实例190 调用存储过程 617 实例191 图片文件存入数据库 620 实例192 数据库图片的输出 622 实例193 利用console控制台运行类中的汉字处理方案 624 实例194 Servlet中的汉字处理方案 625 实例195 JSP中的汉字...

    MySQL 5.1中文手冊

    4.2. 调用MySQL程序 4.3. 指定程序选项 4.3.1. 在命令行上使用选项 4.3.2. 使用选项文件 4.3.3. 用环境变量指定选项 4.3.4. 使用选项设置程序变量 5. 数据库管理 5.1. MySQL服务器和服务器启动脚本 5.1.1. 服务器端...

    java源码包4

    摘要:Java源码,初学实例,EJB调用实例  各种EJB之间的调用源码示例,用远程接口的引用访问EJB、函数将被FirstEJB调用,同时它将调用secondEJB 基于JAVA的UDP服务器模型源代码 2个目标文件 摘要:Java源码,网络...

    java源码包3

    摘要:Java源码,初学实例,EJB调用实例  各种EJB之间的调用源码示例,用远程接口的引用访问EJB、函数将被FirstEJB调用,同时它将调用secondEJB 基于JAVA的UDP服务器模型源代码 2个目标文件 摘要:Java源码,网络...

    Java开发实战1200例(第1卷).(清华出版.李钟尉.陈丹丹).part3

    实例157 动态调用类中的方法 204 实例158 动态实例化类 205 实例159 创建长度可变的数组 206 实例160 利用反射重写toString()方法 208 实例161 反射与动态代理 209 7.3 常见的未检查型异常 210 实例162 算数异常 210...

    java源码包2

    摘要:Java源码,初学实例,EJB调用实例  各种EJB之间的调用源码示例,用远程接口的引用访问EJB、函数将被FirstEJB调用,同时它将调用secondEJB 基于JAVA的UDP服务器模型源代码 2个目标文件 摘要:Java源码,网络...

Global site tag (gtag.js) - Google Analytics