JDBC回顾四CallableStatement进行存储过程的调用

2023-12-22 05:08

本文主要是介绍JDBC回顾四CallableStatement进行存储过程的调用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

存储过程在我们的数据库中使用是比较频繁的一种结构,他可以大大简化sql语句的书写。在java中,我们利用CallableStatement接口,进行存储过程的调用。

CallableStatement 接口:超级接口有PreparedStatement, Statement, Wrapper。

用于执行 SQL 存储过程的接口。JDBC API 提供了一个存储过程 SQL 转义语法,该语法允许对所有 RDBMS 使用标准方式调用存储过程。此转义语法有一个包含结果参数的形式和一个不包含结果参数的形式。如果使用结果参数,则必须将其注册为 OUT 参数。其他参数可用于输入、输出或同时用于二者。参数是根据编号按顺序引用的,第一个参数的编号是 1。

IN 参数值是使用继承自 PreparedStatement 的 set 方法设置的。在执行存储过程之前,必须注册所有 OUT 参数的类型;它们的值是在执行后通过此类提供的 get 方法获取的

CallableStatement 可以返回一个 ResultSet 对象或多个 ResultSet 对象。多个 ResultSet 对象是使用继承自 Statement 的操作处理的。

Types 类:定义用于标识一般 SQL 类型(称为 JDBC 类型)的常量的类。在其中有许多静态的变量标示。
此类永远是不可序列化的。

设定的存储过程代码:在dos模式下记得转换结束标志
mysql> create procedure p(-> in v_a int,in v_b int,out v_c int,inout v_d int)-> begin-> if(v_a > v_b) then-> select v_a into v_c;-> else-> select v_b into v_c;-> end if;-> select (v_d+1) into v_d;-> end; //
Query OK, 0 rows affected (0.08 sec)
// 求输入参数的最大值,在v_d上加1再赋值给v_d-----------------------------------------------------------------------public class JdbcCall {public static void main(String[] args){Connection conn =null;CallableStatement ctmt = null;  //注意此时为CallableStatementResultSet rs = null;try{Class.forName("com.mysql.jdbc.Driver"); //建立驱动conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/studemo","root","root");//建立连接ctmt = conn.prepareCall("Call p(?,?,?,?)");     //创建语句ctmt.setInt(1, 2);   //参数值的设置参数一表示占位符位置,参数二表示传递的值ctmt.setInt(2, 4);//ctmt.setInt(3, x); 3为输出不需要进行设置值ctmt.setInt(4, 6);   // 4 既为输入,又为输出 ctmt.registerOutParameter(3, Types.INTEGER);   ctmt.registerOutParameter(4, Types.INTEGER);// 每一个输出参数都要进行注册设置输出类型 参数一 占位符位置,参数二表示类型。Types也是java.sql下的一个类ctmt.execute();//执行语句   System.out.println(ctmt.getInt(3));  // 通过get方法进行获取System.out.println(ctmt.getInt(4));}catch(ClassNotFoundException e){e.printStackTrace();}catch(SQLException e){e.printStackTrace();}finally{try{if(rs!=null){rs.close();rs=null;}if(ctmt!=null){ctmt.close();ctmt=null;}if(conn!=null){conn.close();conn=null;}}catch(SQLException e){e.printStackTrace();                }}}  }

这篇关于JDBC回顾四CallableStatement进行存储过程的调用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/522705

相关文章

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

SpringBoot 整合 Grizzly的过程

《SpringBoot整合Grizzly的过程》Grizzly是一个高性能的、异步的、非阻塞的HTTP服务器框架,它可以与SpringBoot一起提供比传统的Tomcat或Jet... 目录为什么选择 Grizzly?Spring Boot + Grizzly 整合的优势添加依赖自定义 Grizzly 作为

使用zabbix进行监控网络设备流量

《使用zabbix进行监控网络设备流量》这篇文章主要为大家详细介绍了如何使用zabbix进行监控网络设备流量,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录安装zabbix配置ENSP环境配置zabbix实行监控交换机测试一台liunx服务器,这里使用的为Ubuntu22.04(

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

Idea调用WebService的关键步骤和注意事项

《Idea调用WebService的关键步骤和注意事项》:本文主要介绍如何在Idea中调用WebService,包括理解WebService的基本概念、获取WSDL文件、阅读和理解WSDL文件、选... 目录前言一、理解WebService的基本概念二、获取WSDL文件三、阅读和理解WSDL文件四、选择对接