mysql存储过程中and_MySQL存储过程 AND 在JAVA中的程序调用

package com.test;

import java.sql.CallableStatement;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.Types;

public class Connect {

public static void main(String[] args) {

/* JDBC连接MySQL数据库的参数 */

String driverName = "com.mysql.jdbc.Driver";

String userName = "root";

String userPasswd = "admin";

String dbName = "stopro";

String url = "jdbc:mysql://localhost/" + dbName + "?user=" + userName

+ "&password=" + userPasswd;

Connection connection = null;

CallableStatement stmt = null;

try {

// 加载数据库驱动程序

Class.forName(driverName).newInstance();

// 连接数据库

connection = DriverManager.getConnection(url);

// 调用存储过程,此存储过程有2个参数

stmt = connection.prepareCall("{call p3(?,?)}");

// 第一个参数是输入的,在此设置第一个参数的值:将第一个参数设置成整数值1

stmt.setInt(1, 1);

// 第二个参数是输出的,在此设置第二个参数的输出类型为VARCHAR

stmt.registerOutParameter(2, Types.VARCHAR);

// 执行存储过程

boolean hadResults = stmt.execute();

// 如果有查询语句的话,此执行过程会返回结果集,在此处理结果集里面的东西

System.out.println("Data from table:");

while (hadResults) {

ResultSet rs = stmt.getResultSet();

while(rs.next()){

String id = rs.getString(1);

String name = rs.getString(2);

System.out.println("ID = "+id+"\tName = " + name);

}

hadResults = stmt.getMoreResults();

}

// 获取存储过程的返回值

System.out.println("\nData from procedure:");

String name = stmt.getString(2); // 获得第二个参数,因为第二个参数是输出类型的

System.out.println("Name = " + name);

}

catch (Exception e) {

System.out.println(e.toString());

}

finally {

try {

stmt.close();

connection.close();

} catch (Exception ex) {

System.out.println(ex.getMessage());

}

}

}

}

1

0

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2011-12-14 11:09

浏览 1366

评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值