First time I am trying to call procedure in hibernate like -
Session session = HibernateUtil.getFirstFactory().getCurrentSession();
session.beginTransaction();
Query q = getSession().getNamedQuery("select");
q.setInteger("locationid", locId);
cDbInsts = (List<SpCustsitesettings>) q.list();
MY hbm file SpCustsitesettings.hbm.xml is -
<hibernate-mapping>
<class name="glb.chatmeter.db.SpCustsitesettings">
<id name="cmcustLocId" type="int">
<column name="CMCustLocID"/>
</id>
<property name="cpid" type="string">
<column name="CPID">
</column>
</property>
</class>
<sql-query name="select" callable="true">
<return alias="select" class="glb.chatmeter.db.SpCustsitesettings">
<return-property name="cmcustLocId" column="CMCustLocID" />
<return-property name="cpid" column="CPID" />
</return>
<query-param name="locationid" type="int" />
{call select(:locationid)}
</sql-query>
and I have added this in config file like -
<mapping resource="xml/SpCustsitesettings.hbm.xml"/>
But when I goes to execute my query showing an exception -
java.lang.StackOverflowError
at gnu.xml.pipeline.ValidationConsumer$ChildrenRecognizer.patchNext(ValidationConsumer.java:1570)
at gnu.xml.pipeline.ValidationConsumer$ChildrenRecognizer.patchNext(ValidationConsumer.java:1591)
at gnu.xml.pipeline.ValidationConsumer$ChildrenRecognizer.patchNext(ValidationConsumer.java:1580)
at gnu.xml.pipeline.ValidationConsumer$ChildrenRecognizer.patchNext(ValidationConsumer.java:1580)
at gnu.xml.pipeline.ValidationConsumer$ChildrenRecognizer.patchNext(ValidationConsumer.java:1591)
.............................................................................
And Program going turn off. Here is my Procedure -
CREATE DEFINER=`root`@`%` PROCEDURE `select`(IN locationid INT)
BEGIN
SELECT cmcustLocId, cpid FROM `custsitesettings` WHERE `CMCustLocID` = locationid;
END
What is the problem I am not following can any one help me.
The problem lies within your mapping file SpCustsitesettings.hbm.xml
.
Change
<hibernate-mapping>
.....
<sql-query name="select" callable="true">
<return alias="select" class="glb.chatmeter.db.SpCustsitesettings">
<return-property name="cmcustLocId" column="CMCustLocID" />
<return-property name="cpid" column="CPID" />
</return>
<query-param name="locationid" type="int" />
{call select(:locationid)}
</sql-query>
</hibernate-mapping>
to
<sql-query name="select" callable="true">
<return alias="select" class="glb.chatmeter.db.SpCustsitesettings">
<return-property name="cmcustLocId" column="CMCustLocID" />
<return-property name="cpid" column="CPID" />
</return>
<query-param name="locationid" type="int" />
<![CDATA[CALL select(:locationid)]]>
</sql-query>
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.