【08】CallableStatement

博客围绕CallableStatement展开,它是java.sql包中用于执行SQL存储过程的接口,继承自PreparedStatement。详细介绍了调用无返回值和有返回值存储过程的方法,包括存储过程内容及代码实现,有返回值的存储过程可通过传入参数返回对应结果。

1. CallableStatement

  • java.sql包

  • 用于执行 SQL 存储过程的接口

  • 继承自PreparedStatement

     public interface CallableStatement extends PreparedStatement
    

2. 调用没有返回值的存储过程

2.1 存储过程

	create or replace procedure test_a(param1 in varchar2, param2 in varchar2)
	  as
	begin
	      insert into Dept(deptno,dname) values(param1, param2);
	end;

2.2 代码实现

	Connection conn = ConnectionUtil.getConnection();
	CallableStatement cstmt = null;
	try {
		int deptNo = 26;
		String dname = "dname26";
			
		//实例化
		cstmt = conn.prepareCall("{call test_a(?,?)}");
		//设置参数
		cstmt.setInt(1, deptNo);
		cstmt.setString(2, dname);
		
		//执行
		int i = cstmt.executeUpdate();
		System.out.println("影响行数:"+i);
	} catch (Exception e) {
		e.printStackTrace();
	} finally {
		ConnectionUtil.closeCallableStatement(cstmt);
		ConnectionUtil.closeConnection(conn);
	}

3. 调用有返回值的存储过程

3.1 存储过程

此存储过程通过传入的参数(Name),返回一个参数(address)。

     create or replace procedure demo_procedure(namedemo in varchar2,addressdemo out varchar2)
    	as
   	 begin 
    	select address into addressdemo from system.demo where name=namedemo;
     end;

2.2 代码实现

   	Connection conn = ConnectionUtil.getConnection();
   	CallableStatement cstmt = null;
    try {  
        cstmt = conn.prepareCall("{ call dem_procedure(?,?) }");  
        cstmt .setString(1, "kalision");  
        cstmt .registerOutParameter(2, Types.VARCHAR);  // 注册输出参数
        cstmt .execute();  
        String testPrint = cstmt .getString(2);  
        System.out.println("存储过程返回的值是:"+testPrint);  
    } catch (Exception ex) {  
        ex2.printStackTrace();  
    } finally{  
      	ConnectionUtil.closeCallableStatement(cstmt);
		ConnectionUtil.closeConnection(conn);
	}
TestRunner: java.util.concurrent.TimeoutException: The panel should receive IME insets 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at android.view.inputmethod.cts.util.TestUtils.waitOnMainUntil(TestUtils.java:152) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at android.view.inputmethod.cts.ImeInsetsVisibilityTest.testEditorWontCoveredByImeWhenInputWindowBehindPanel(ImeInsetsVisibilityTest.java:386) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at java.lang.reflect.Method.invoke(Native Method) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:61) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:148) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:142) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at java.util.concurrent.FutureTask.run(FutureTask.java:343) 08-06 15:58:47.273 10697 13496 13530 E TestRunner: at java.lang.Thread.run(Thread.java:1119)
08-16
08-01 14:40:13.539 10258 12327 12342 E TestRunner: failed: testTelephonyManagerWithFeatureMapping(android.telephony.cts.TelephonyManagerTest) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: ----- begin exception ----- 08-01 14:40:13.541 10258 12327 12342 E TestRunner: java.lang.AssertionError 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.Assert.fail(Assert.java:87) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.Assert.assertTrue(Assert.java:42) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.Assert.assertFalse(Assert.java:65) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.Assert.assertFalse(Assert.java:75) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at android.telephony.cts.TelephonyManagerTest.testTelephonyManagerWithFeatureMapping(TelephonyManagerTest.java:1104) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at java.lang.reflect.Method.invoke(Native Method) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:61) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:148) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:142) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at java.util.concurrent.FutureTask.run(FutureTask.java:264) 08-01 14:40:13.541 10258 12327 12342 E TestRunner: at java.lang.Thread.run(Thread.java:1012)
08-02
06-25 03:08:55.954 1047 556 3232 E Camera3-Device: Camera 100: initialize: Could not open camera session: Function not implemented (-38) 06-25 03:08:55.954 1047 556 3232 E Camera2ClientBase: initializeImpl: Camera 100: unable to initialize device: Function not implemented (-38) 06-25 03:08:55.954 1047 556 3232 E CameraService: connectHelper: Could not initialize client from HAL. 06-25 03:08:55.954 1047 556 3232 I Camera2Client: Camera 0: Closed 06-25 03:08:55.954 1047 556 3232 D Camera2ClientBase: Camera 100: start to disconnect 06-25 03:08:55.955 1047 556 3232 D Camera2ClientBase: Camera 100: serializationLock acquired 06-25 03:08:55.955 1047 556 3232 D Camera2ClientBase: Camera 100: Shutting down 06-25 03:08:55.955 1047 556 3232 D Camera2ClientBase: Camera 100: start to cacheDump 06-25 03:08:55.955 1047 556 3232 I Camera3-Device: disconnectImpl: E 06-25 03:08:55.955 1047 556 3232 E CameraService: unregisterMonitorUid: Trying to unregister uid: 10066 which is not monitored! 06-25 03:08:55.955 1047 556 3232 I CameraService: disconnect: Disconnected client for camera 100 for PID 3801 06-25 03:08:55.956 1047 556 3232 D cameraserver: FGS Logger Transaction failed 06-25 03:08:55.956 1047 556 3232 D cameraserver: -129 06-25 03:08:55.956 1047 556 3232 I Camera2ClientBase: ~Camera2ClientBase: Client object's dtor for Camera Id 100 completed. Client was: android.camera.cts (PID 3801, UID 10066) 06-25 03:08:55.956 1047 556 3232 I Camera3-Device: disconnectImpl: E 06-25 03:08:55.986 10066 3801 3817 E TestRunner: failed: testCameraExternalConnected(android.hardware.cts.CameraTest) 06-25 03:08:55.986 10066 3801 3817 E TestRunner: ----- begin exception ----- 06-25 03:08:55.986 1000 882 978 W libprocessgroup: SetCgroup::ExecuteForProcess: failed to open /dev/stune/top-app/cgroup.procs: No such file or directory 06-25 03:08:55.987 1000 494 494 I BpBinder: onLastStrongRef automatically unlinking death recipients: 06-25 03:08:55.987 10066 3801 3817 E TestRunner: java.lang.AssertionError: Devices with external camera support must have all listed cameras be connected and openable for testing 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at android.hardware.cts.CameraTest.testCameraExternalConnected(CameraTest.java:3514) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at java.lang.reflect.Method.invoke(Native Method) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:61) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:148) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:142) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at java.util.concurrent.FutureTask.run(FutureTask.java:264) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at java.lang.Thread.run(Thread.java:1012) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: Caused by: java.lang.RuntimeException: Fail to connect to camera service 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at android.hardware.Camera.<init>(Camera.java:513) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at android.hardware.Camera.open(Camera.java:399) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: at android.hardware.cts.CameraTest.testCameraExternalConnected(CameraTest.java:3511) 06-25 03:08:55.987 10066 3801 3817 E TestRunner: ... 9 more 06-25 03:08:55.988 10066 3801 3817 E TestRunner: ----- end exception -----
最新发布
09-03
WindowManager: Window{a06d7b0 u0 Toast} state from COMMIT_DRAW_PENDING to READY_TO_SHOW; reason: commitFinishDrawingLocked 08-05 10:18:39.918 1000 3093 3207 I WindowManager: Window{a06d7b0 u0 Toast} state from READY_TO_SHOW to HAS_DRAWN; reason: performShowLocked 08-05 10:18:39.919 1000 3093 3207 D CoreBackPreview: return markWindowHasDrawn mComposed: false mWaitTransition: false 08-05 10:18:39.919 1000 3093 3207 D ActivityTaskManager: removeStartingWindowAnimation for activity=ActivityRecord{137003130 u0 com.android.settings/.applications.InstalledAppDetails t202 f}} prepareAnimation=true,Callers=com.android.server.wm.ActivityRecord.removeStartingWindow:3390 com.android.server.wm.ActivityRecord.onFirstWindowDrawn:8033 com.android.server.wm.WindowState.performShowLocked:4910 com.android.server.wm.WindowStateAnimator.commitFinishDrawingLocked:402 com.android.server.wm.DisplayContent.lambda$new$8:1138 08-05 10:18:39.919 1000 3093 3207 D ActivityTaskManager: Clearing startingData for activity=ActivityRecord{137003130 u0 com.android.settings/.applications.InstalledAppDetails t202 f}} mStartingData=null mStartingSurface=null 08-05 10:18:39.919 10540 26040 26063 E TestRunner: ----- begin exception ----- 08-05 10:18:39.919 10540 26040 26063 E TestRunner: java.lang.RuntimeException: java.lang.AssertionError 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at com.android.compatibility.common.util.SystemUtil.eventually(SystemUtil.java:359) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at com.android.compatibility.common.util.SystemUtil.eventually(SystemUtil.java:332) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at android.hibernation.cts.AutoRevokeTest.testAutoRevoke_userAllowlisting(AutoRevokeTest.kt:1063) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at java.lang.reflect.Method.invoke(Native Method) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:61) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:148) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:142) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at java.util.concurrent.FutureTask.run(FutureTask.java:343) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at java.lang.Thread.run(Thread.java:1119) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: Caused by: java.lang.AssertionError 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.Assert.fail(Assert.java:87) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.Assert.assertTrue(Assert.java:42) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.Assert.assertFalse(Assert.java:65) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at org.junit.Assert.assertFalse(Assert.java:75) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at android.hibernation.cts.AutoRevokeTest$testAutoRevoke_userAllowlisting$lambda$18$lambda$17$$inlined$eventually$1.run(AutoRevokeTest.kt:752) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: at com.android.compatibility.common.util.SystemUtil.eventually(SystemUtil.java:347) 08-05 10:18:39.919 10540 26040 26063 E TestRunner: ... 11 more 08-05 10:18:39.919 10540 26040 26063 E TestRunner: ----- end exception ----- 08-05 10:18:39.919 1000 3093 3207 D DisplayModeDirector: setAppRequest displayId : 0 modeId: 1 requestedRefreshRate: 0.0 requestedMinRefreshRateRange: 0.0 requestedMaxRefreshRateRange: 120.00001 日志分析
08-06
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值