JAVA通过调用数据库函数调用存储过程

发布于 2022-10-15 09:18:34 字数 2419 浏览 9 评论 0

JAVA通过调用数据库函数调用存储过程
下面将举一个通过数据库函数来调用存储过程:

创建数据库函数存储过程

  1. CREATE OR REPLACE FUNCTION stu_proc (
  2.   v_id IN NUMBER
  3. )
  4. RETURN VARCHAR2 IS
  5.     v_name VARCHAR2(20);
  6. BEGIN   SELECT o.sname INTO v_name FROM student o WHERE o.id=v_id;
  7.   RETURN v_name;
  8. EXCEPTION  WHEN OTHERS THEN RETURN '数据未找到';
  9. END;

复制代码JAVA通过调用数据库函数调用存储过程

  1. package com.ljq.test;
  2. import java.sql.CallableStatement;
  3. import java.sql.Connection;import java.sql.SQLException;
  4. import java.sql.Types;
  5. public class ProceTest {
  6.     public static void main(String[] args) throws Exception {
  7.         Connection conn = null;
  8.         CallableStatement statement = null;
  9.         //?表示函数return的值, stu_proc是数据库函数名
  10.         //存储过程的out和in都是以参数传进,这就是函数和存储过程的区别之一
  11.        String sql = "{?=call stu_proc(?)}";
  12.         try {
  13.             conn = ConnUtils.getConnection();
  14.             statement = conn.prepareCall(sql);
  15.             statement.registerOutParameter(1, Types.VARCHAR);
  16.             statement.setInt(2, 36);
  17.             statement.execute();
  18.             //具体值或数据未找到
  19.             String msg=statement.getString(1);
  20.             System.out.println(msg);
  21.         } catch (SQLException e) {
  22.             e.printStackTrace();
  23.         } finally {
  24.             ConnUtils.free(null, statement, conn);
  25.        }    }}

复制代码

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文