Java执行存储过程
1、JDBC调用存储过程: CallableStatement
/**
*p是要调用的存储过程的名字,存储过程的4个参数,用4个?号占位符代替
*其余地方写法固定
*/
CallableStatement cstmt = conn.prepareCall("{call p(?,?,?,?)}");
/**
*告诉JDBC,这些个参数,哪些是输出参数,输出参数的类型用java.sql.Types来指定
*下面的意思是,第3个?和第4个?是输出参数,类型是INTEGER的
*Types后面具体写什么类型,得看你的存储过程参数怎么定义的
*/
cstmt.registerOutParameter(3, Types.INTEGER);
cstmt.registerOutParameter(4, Types.INTEGER);
/**
*在我这里第1个?和第2个?是输入参数,第3个是输出参数,第4个既输入又输出
*下面是设置他们的值,第一个设为3,第二个设为4,第4个设置为5
*没设第3个,因为它是输出参数
*/
cstmt.setInt(1, 3);
cstmt.setInt(2, 4);
cstmt.setInt(4, 5);
//执行
cstmt.execute();
//把第3个参数的值当成int类型拿出来
int three = cstmt.getInt(3);
System.out.println(three);
//把第4个参数的值当成int类型拿出来
int four = cstmt.getInt(4);
System.out.println(four);
//用完别忘给人家关了,后开的先关
cstmt.close();
conn.close();
2、JdbcTemplate()调用存储过程
getJdbcTemplate().execute(new ConnectionCallback() {
            @Override
            public Object doInConnection(Connection con) throws SQLException,
                    DataAccessException {
                CallableStatement prepareCall = con.prepareCall("{call update "
                        + "(?)}");
                prepareCall.setString(1, num);
                prepareCall.execute();
                return null;
            }
        });
Java执行存储过程的更多相关文章
- sqlserver学习2---java执行存储过程
		一.存储过程 1.新增操作存储过程 --------------1.新建 增加学生的存储过程---------------------------- set IDENTITY_INSERT stude ... 
- JAVA使用JDBC技术操作SqlServer数据库执行存储过程
		Java使用JDBC技术操作SqlServer数据库执行存储过程: 1.新建SQLSERVER数据库:java_conn_test 2.新建表:tb_User 3.分别新建三个存储过程: 1>带 ... 
- java 执行mysql 8.0.11存储过程报错The user specified as a definer ('root'@'10.%.%.%') does not exist解决办法
		执行存储过程,报错 java.sql.SQLException: The user specified as a definer ('root'@'10.%.%.%') does not exist ... 
- Java中执行存储过程和函数(web基础学习笔记十四)
		一.概述 如果想要执行存储过程,我们应该使用 CallableStatement 接口. CallableStatement 接口继承自PreparedStatement 接口.所以CallableS ... 
- Java中执行存储过程和函数
		装载于:http://www.cnblogs.com/liunanjava/p/4261242.html 一.概述 如果想要执行存储过程,我们应该使用 CallableStatement 接口. Ca ... 
- Java对存储过程的调用方法 --转载
		一.Java如何实现对存储过程的调用: A:不带输出参数的 create procedure getsum <--此处为参数--> as declare @sum int<--定义变 ... 
- 【转】java调用存储过程和函数
		一.概述 如果想要执行存储过程,我们应该使用 CallableStatement 接口. CallableStatement 接口继承自PreparedStatement 接口.所以CallableS ... 
- clob字段的值插入和查询N种方法【包括java调用存储过程传入clob参数】
		import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IOException; import jav ... 
- java调用存储过程、存储函数
		需要用到的接口 接口 CallableStatement JDK文档对改接口的说明: public interface CallableStatement extends PreparedStatem ... 
随机推荐
- HDU 4009——Transfer water——————【最小树形图、不定根】
			Transfer water Time Limit:3000MS Memory Limit:65768KB 64bit IO Format:%I64d & %I64u Subm ... 
- Kindeditor单独调用单图上传增加预览
			html代码: <p><input type="hidden" id="url1" name="IDCardPicture1&quo ... 
- C++ 0x
- centos7 mod_gearman 3.0.1 打包rpm
			wget https://github.com/sni/mod_gearman/archive/v3.0.1.tar.gz -O /root/rpmbuild/SOURCES/mod_gearman- ... 
- python JSON性能测试与simplejson对比
			简单测试了一下,如果用JSON,也就是python2.6以上自带的json处理库,效率还算可以: 1K的数据,2.9GHz的CPU,单核下每秒能dump:36898次.大约是pyamf的5倍.但数据量 ... 
- 笨办法学Python(三十三)
			习题 33: While 循环 接下来是一个更在你意料之外的概念: while-loop``(while 循环).``while-loop 会一直执行它下面的代码片段,直到它对应的布尔表达式为 Fal ... 
- Linux终端(terminal)清屏命令
			windows CMD终端的清屏命令是cls Linux终端中的清屏命令有 1) clear 2) reset 
- Altium_Designer-PCB的覆铜步骤
			1.覆铜的意义 覆铜,就是将PCB上闲置的空间作为基准面,然后用固体铜填充,这些铜区又称为灌铜.敷铜的意义在于,减小地线阻抗,提高抗干扰能力:降低压降,提高电源效率:还有,与地线相连,减小环路 ... 
- Node.js与npm安装(转载)
			2009年的JSCOnf大会上,一个叫Ryan Dahl的年轻程序员向人们展示了一个他正在做的项目,一个基于Google V8引擎的JavaScript运行平台,它提供了一套事件循环和低IO的应用程序 ... 
- js 去掉指定符号的字符串做法
			//去掉字符串末尾指定符号 function RemoveSymbol(str, symbol) { if (str.charAt(str.length - 1) == symbol) { str = ... 
