今天在使用Hibernate開發項目時,遇到一個Oracle Function的問題.
在項目開發中,所有單據的號碼產生都是通過一個Function來產生.在這個Function中有一些DML語法,所以不能使用select fun_...() Into v_ref from dual的方法來取得返回結果.
經查詢相關資料,Hibernate要求在執行Procedure和Function時都要返回一個游標,所以變通一下方法,我們增加另外一層Function處理.
新定義一個Function 如下:
Function fun_get_vou_web(....)
RETURN SYS_REFCURSOR
as
v_vou varchar2(20);
st_cursor SYS_REFCURSOR;
BEGIN
v_vou := fun_get_vou(....);
OPEN st_cursor FOR
SELECT v_vou as vouno from dual ;
RETURN st_cursor;
END;
然后在hbm.xml中配置:
<sql-query name="getNewAppNo" callable="true">
<return-scalar column="vouno" type="string"/>
{ ? = call fun_get_vou_web(.......) }
</sql-query>
最后在java中查詢name為getNewAppNo的執行結果即可.

本文介绍了解决OracleFunction与Hibernate集成时遇到的问题。通过新增一层Function来处理,实现利用SYS_REFCURSOR返回结果,并在Hibernate配置文件中进行相应设置。
7387

被折叠的 条评论
为什么被折叠?



