我需要使用休眠在 DB_TABLE 上执行 SQL 子句查询。in 子句包含成对的值。我在组件映射的帮助下查询 (tid, mid) 对,见下文。
我现在需要另外对另一对示例(tid,组织)执行 in 子句查询。我该怎么做呢?
目标 SQL 查询
select * from DB_TABLE where ( c_tid, c_mid ) in ( ('t1', 'm1'), etc. )
Java查询代码
function List<DBTable> getDBTableList( List<TidMidId> tidMidList ) {
Criterion crit = Restrictions.in( "tidMidId", tidMidList.toArray() );
// pom is hibernate wrapper
return pom.getObjects( DBTable.class, crit );
}
休眠映射:
<class name="com.DBTable" table="DB_TABLE" >
<id name="id" type="long" column="K_ID">
<generator class="sequence">
<param name="sequence">DB_TABLE$SEQ</param>
</generator>
</id>
<component name="tidMidId" class="com.TidMidId">
<property name="tid" type="string" column="C_TID"/>
<property name="mid" type="string" column="C_MID"/>
</component>
<property name="organisation" type="string" column="C_ORGANISATION"/>
<property name="createTimestamp" type="timestamp" column="D_CREATE_TIMESTAMP"/>
<property name="modTimestamp" type="timestamp" column="D_MOD_TIMESTAMP"/>
</class>