1

下面是存储过程:

create or replace procedure 
proc_emp_name(v_emp out emp.emp_name%TYPE, v_empid in emp.emp_id%TYPE)
is
begin
select emp_name into v_emp from emp where emp_id = v_empid;
dbms_output.put_line('Emp Name: ' || v_emp);
dbms_output.put_line('Procedure created successfully!!!');
end;

我想使用 Native SQL 调用它,按照这个链接但不知道如何OUT从过程中检索参数。

http://www.mkyong.com/hibernate/how-to-call-store-procedure-in-hibernate/

请让我知道调用该过程并从中获取结果的最简单方法。

编辑

正如建议的那样,检查文档,我将具有第一个参数的 Proc 修改SYS_REFCURSOR为如下:

create or replace procedure
proc_empname_refcursor(v_empname OUT SYS_REFCURSOR, v_deptid in emp.emp_id%type)
is 
begin
open v_empname for select * from dept where dept_id = v_deptid;
end;

我可以使用它来调用它,NamedQuery但由于其他一些限制,我不想在映射文件中添加任何内容。我尝试了以下代码来调用proc而不使用NamedQuery,但没有成功:

Query query = session.createSQLQuery(
                "CALL proc_empname_refcursor(?, :deptId)")
                .addEntity(Dept.class)
                .setParameter("deptId", new Integer(2));

            List<Dept> departments = query.list();
            for(int i=0; i<departments.size(); i++){
                Dept department = (Dept)departments.get(i);
                System.out.println("Dept Id: " + department.getDeptId());
                System.out.println("Dept Name: " + department.getDeptName());
            }

我得到了例外:

org.hibernate.QueryException: Expected positional parameter count: 1, actual parameters: [] [CALL proc_empname_refcursor(?, :deptId)]
at     org.hibernate.impl.AbstractQueryImpl.verifyParameters(AbstractQueryImpl.java:319)
at org.hibernate.impl.SQLQueryImpl.verifyParameters(SQLQueryImpl.java:201)
at org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:145)
at com.jdbc.HibernateStartup.main(HibernateStartup.java:70)

请让我知道如何解决这个问题。

4

2 回答 2

6

我已经设法使用 Hibernate 和 MS SQL Server 中的以下代码从存储过程中获取一个 out 参数:

@Override
public Serializable generate(SessionImplementor session, Object object) throws HibernateException {
    Connection connection = session.connection();
    CallableStatement callable = null;
    try {
        callable = connection.prepareCall("execute [procedure] ?");
        callable.registerOutParameter(1, Types.INTEGER);
        callable.execute();
        int id = callable.getInt(1);

        return id;
    } catch (SQLException e) {
        (...)
    } finally {
        (...)
    }
}
于 2013-06-27T16:49:10.827 回答
1

来自休眠文档

除非您遵循某些过程/函数规则,否则您不能在 Hibernate 中使用存储过程。

对于 Oracle,函数必须返回结果集。过程的第一个参数必须是返回结果集的 OUT。

于 2013-06-27T16:43:18.137 回答