hibernate3 調用oracle預存程序的方法

來源:互聯網
上載者:User

設定檔:

<hibernate-mapping>
    <class name="vo.SshPost" table="ssh_post" >
     <!-- <cache usage="read-write"/>-->
        <id name="postId" type="java.lang.String">
            <column name="post_id" />
            <generator class="native" />
        </id>
       
        <property name="postName" type="java.lang.String">
            <column name="post_name" length="20" />
        </property>
        <property name="postNo" type="java.lang.String">
            <column name="post_no" length="20" />
        </property>
        <filter name="myfilter" condition=":myfilterParam = post_name"/>
      
    </class>

<sql-query callable="true" name="selectAllUsers">
 <return class="vo.SshPost">
     <return-property name="postId" column="POST_ID"/>
     <return-property name="postName" column="POST_NAME"/>
     <return-property name="postNo" column="POST_NO"/>
 </return>
 { call P_TEST(?,:VPOSTNO) }
     </sql-query>

</hibernate-mapping>  

預存程序:

CREATE OR REPLACE PACKAGE TESTPACKAGE  AS

 TYPE Test_CURSOR IS REF CURSOR;

end TESTPACKAGE;

 

CREATE OR REPLACE PROCEDURE P_TEST(P_CURSOR OUT TESTPACKAGE.TEST_CURSOR,
                                   VPOSTNO  IN VARCHAR2) IS

BEGIN
  OPEN P_CURSOR FOR
    SELECT * FROM SSH_POST WHERE POST_NO = VPOSTNO;

END P_TEST;

 

如果不用PACKAGE  則可以使用

CREATE OR REPLACE PROCEDURE P_TEST(P_CURSOR OUT SYS_REFCURSOR,
                                   VPOSTNO  IN VARCHAR2) IS

 

程式調用:

Session session = sessionFactory.openSession();
  Query query = session.getNamedQuery("selectAllUsers");
  List list = query.setParameter("VPOSTNO", "99")

.list();
  System.out.println(list.size());

 

但是有個很鬱悶的問題就是:

當 { call P_TEST(?,:VPOSTNO) } 改為 { call P_TEST(?,?) } 時

程式使用query.setParameter(1, "99")

系統居然報錯:

java.lang.ArrayStoreException
 at java.lang.System.arraycopy(Native Method)
 at java.util.Arrays.copyOf(Unknown Source)
 at java.util.ArrayList.toArray(Unknown Source)
 at org.hibernate.util.ArrayHelper.toTypeArray(ArrayHelper.java:75)
 at org.hibernate.impl.AbstractQueryImpl.typeArray(AbstractQueryImpl.java:831)
 at org.hibernate.impl.AbstractQueryImpl.getQueryParameters(AbstractQueryImpl.java:839)
 at org.hibernate.impl.SQLQueryImpl.getQueryParameters(SQLQueryImpl.java:194)
 at org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:152)

奇怪的hibernate

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.