如果oralce内置的一些函数不能够满足我们开发的要求,那样势必要通过自己写一个函数,那么是如何调用的呢?
我们可以在hbm.xml中调用,例如:
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="com.test" table="TEST">
<id name="id" type="java.lang.String">
<column name="ID" length="12" />
<generator class="assigned" />
</id>
<!--以下是通过SQL来实现的-->
<property name="rs" type="java.lang.Long"
formula="(select count(*) from Xs0101 xs where xs.bjbh = bjbh)" />
</class>
<!--以下是通过自定义函数来实现的-->
<property name="data" type="java.lang.String"
formula="(pckfunction.findSubString(class,’args1’,’args2’,’args3’))" />
</class>
</hibernate-mapping>
在oracle的packages中可以自定义自己提供的函数:
create or replace package pckFunction is
TYPE myrctype IS REF CURSOR;
function getSubTable(tblname in varchar2,
returnColname in varchar2,
findColname in varchar2,
findValue in varchar2) return myrctype;
function findSubString(tblname in varchar2,
returnColname in varchar2,
findColname in varchar2,
findValue in varchar2) return varchar2;
end pckFunction;
3COME考试频道为您精心整理,希望对您有所帮助,更多信息在http://www.reader8.com/exam/