[Oracle]高效的PL/SQL程序设计(五)--调用存储过程返回结果集

Oracle支持通过ref游标在调用存储过程后返回结果集, 使用游标在内存消耗以及时间上都要大大的优于返回数组变量的做法!

示例如下:数据库方面,建立一个Package

create   or   replace  package ref_cur_demo  is
 type rc 
is  ref  cursor ;
 
procedure  ref_cursor(p_owner  in   varchar2 ,p_cursor  in  out rc);
end  ref_cur_demo;

create   or   replace  package body ref_cur_demo  is

 
procedure  ref_cursor(p_owner  in   varchar2 ,p_cursor  in  out rc)
 
is  
 
begin
      
open  p_cursor  for   select   object_name ,object_type  from  all_objects  where  owner  =  p_owner  and  rownum < 3
 
end ;
  
end  ref_cur_demo;

程序方面使用C#建立一个小型应用程序,主要代码如下:

            Oracle.DataAccess.Client.OracleConnection oracleConnection1 = new  OracleConnection( " data source=precolm2;user id=colmtest;password=colmtest " );
            oracleConnection1.Open();
            
string  strSQL  =   @" ref_cur_demo.ref_cursor " ;

            Oracle.DataAccess.Client.OracleDataAdapter da 
=   new  Oracle.DataAccess.Client.OracleDataAdapter();
            Oracle.DataAccess.Client.OracleCommand cmd 
=   new  Oracle.DataAccess.Client.OracleCommand(strSQL,oracleConnection1);
            cmd.CommandType 
=  CommandType.StoredProcedure;

            Oracle.DataAccess.Client.OracleParameter pram 
=   new  Oracle.DataAccess.Client.OracleParameter( " p_owner " ,Oracle.DataAccess.Client.OracleDbType.Varchar2);
            pram.Value 
=   " COLMTEST " ;
            cmd.Parameters.Add(pram);

            Oracle.DataAccess.Client.OracleParameter pram1 
=   new  Oracle.DataAccess.Client.OracleParameter( " p_cursor " ,Oracle.DataAccess.Client.OracleDbType.RefCursor);
            pram1.Direction 
=  ParameterDirection.Output;
            cmd.Parameters.Add(pram1);
            
            da.SelectCommand 
=  cmd;

            DataSet ds 
=   new  DataSet();

            da.Fill(ds);
                
            
this .dataGrid1.DataSource = ds.Tables[ 0 ].DefaultView;


 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Java中调用Oracle中的PL/SQL可以使用JDBC(Java Database Connectivity) API。以下是一个简单的示例代码,演示如何使用JDBC调用Oracle中的存储过程: ```java import java.sql.*; public class PLSQLExample { public static void main(String[] args) { try { // 加载Oracle JDBC驱动程序 Class.forName("oracle.jdbc.driver.OracleDriver"); // 建立数据库连接 Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE", "username", "password"); // 创建CallableStatement对象 CallableStatement stmt = conn.prepareCall("{ call my_stored_procedure(?, ?, ?) }"); // 设置输入参数 stmt.setString(1, "input_param1_value"); stmt.setInt(2, 123); // 注册输出参数 stmt.registerOutParameter(3, java.sql.Types.VARCHAR); // 执行存储过程 stmt.execute(); // 获取输出参数值 String outputValue = stmt.getString(3); System.out.println("Output Value: " + outputValue); // 关闭连接和语句 stmt.close(); conn.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 在这个示例中,我们首先加载Oracle JDBC驱动程序,并使用`DriverManager`类建立一个数据库连接。然后,我们创建一个`CallableStatement`对象,并将存储过程调用语句作为参数传递给它。接下来,我们设置输入参数的值,并使用`registerOutParameter()`方法注册输出参数。然后,我们执行存储过程并使用`getString()`方法获取输出参数的值。最后,我们关闭连接和语句。 请注意,这个示例假设你已经有一个名为“my_stored_procedure”的存储过程Oracle中,并且该存储过程有一个输入参数和一个输出参数。如果你想在实际项目中使用这个示例代码,请根据你的需求修改代码中的参数和存储过程名。 ### 回答2: 以下是一个简单的Java代码示例,演示了如何使用Java JDBC来调用Oracle中的PL/SQL过程: ```java import java.sql.CallableStatement; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class CallPLSQLProcedure { public static void main(String[] args) { Connection conn = null; CallableStatement cs = null; try { // 连接到Oracle数据库 conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE", "用户名", "密码"); // 准备调用PL/SQL过程的语句 String sql = "{call PROCEDURE_NAME(?, ?)}"; // 替换为实际的存储过程名 // 创建CallableStatement对象 cs = conn.prepareCall(sql); // 设置输入参数的值 cs.setInt(1, 123); // 替换为实际的输入参数值 // 注册输出参数的数据类型 cs.registerOutParameter(2, java.sql.Types.VARCHAR); // 替换为实际的输出参数类型 // 执行存储过程 cs.execute(); // 获取输出参数的值 String output = cs.getString(2); // 替换为实际的输出参数位置 System.out.println("输出参数的值为:" + output); } catch (SQLException e) { e.printStackTrace(); } finally { try { // 关闭连接和语句对象 if (cs != null) { cs.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } } } ``` 注意替换代码中的以下部分: 1. `"jdbc:oracle:thin:@localhost:1521:XE"`:替换为实际的Oracle数据库连接字符串。 2. `"用户名"`和`"密码"`:替换为实际的数据库用户名和密码。 3. `"PROCEDURE_NAME"`:替换为实际的PL/SQL存储过程名。 4. `setInt(1, 123)`:根据实际情况设置输入参数的值。 5. `registerOutParameter(2, java.sql.Types.VARCHAR)`和`getString(2)`:根据实际情况设置和获取输出参数的值。 这是一个简单的示例,根据实际需求,你可能需要进行更多的参数设置和结果处理。 ### 回答3: 在Java中,可以使用JDBC来连接和操作Oracle数据库,并调用Oracle中的PL/SQL过程。以下是一个简单的示例代码,通过Java代码调用Oracle数据库中的PL/SQL过程: import java.sql.*; public class OraclePLSQL { public static void main(String[] args) { // 定义数据库连接信息 String url = "jdbc:oracle:thin:@localhost:1521/xe"; // 指定数据库连接URL String user = "<your_username>"; // 替换为您的数据库用户名 String password = "<your_password>"; // 替换为您的数据库密码 // 定义Oracle PL/SQL过程调用语句 String plsql = "{call YOUR_PLSQL_PROCEDURE (?, ?, ?)}"; // 替换为您的PL/SQL过程名 try { // 加载Oracle JDBC驱动程序 Class.forName("oracle.jdbc.driver.OracleDriver"); // 建立数据库连接 Connection conn = DriverManager.getConnection(url, user, password); // 创建CallableStatement对象,用于调用PL/SQL过程 CallableStatement cs = conn.prepareCall(plsql); // 设置输入参数 cs.setString(1, "input1"); // 替换为您的输入参数1 cs.setString(2, "input2"); // 替换为您的输入参数2 // 注册输出参数 cs.registerOutParameter(3, Types.VARCHAR); // 替换为您的输出参数 // 执行PL/SQL过程调用 cs.execute(); // 获取输出参数的值 String output = cs.getString(3); System.out.println("Output: " + output); // 输出参数值 // 关闭数据库连接 cs.close(); conn.close(); } catch (Exception e) { e.printStackTrace(); } } } 上述代码示例中,您需要将url、user、password分别替换为您的数据库连接信息;将plsql替换为您要调用PL/SQL过程名;并根据需求设置输入参数和注册输出参数。然后,您可以执行Java代码,以实现对Oracle数据库PL/SQL过程的调用

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值