有没有什么方法可以加入两个表而没有它们之间的直接关系,但是在hibernate中有两个常见的字段?
我有两个名为boiler_plates和profile的表,它们之间没有直接关系,但有一个名为contract_id的公共字段。
我在bp.bt_contracts = p.contract_id上写了“来自Boiler_Plates bp内部联接个人资料p”的查询,但它继续抛出错误。 “ 意外的标记:在第1行第75列[来自com.catapult.bid.model.Boiler_Plates作为bp内连接配置文件为p在bp.bt_contracts = p.contract_id,其中bp.bt_contracts = 1]“。
以下是boiler_plates和profiles的hibernate映射文件。
boiler_plates的映射文件。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping SYSTEM "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.catapult.bid.model" default-access="field" >
<class name="Boiler_Plates" table="bt_boiler_plates" schema="bidtool">
<id name="boiler_plate_id" type="int" column="boiler_plate_id">
<generator class="sequence">
<param name="sequence">bidtool.boiler_plates_boiler_plate_id_seq</param>
</generator>
</id>
<property name="boilerPlateName" type="string">
<column name="boiler_plate_name" length="20" not-null="true" />
</property>
<property name="editable" type="int">
<column name="editable"/>
</property>
<property name="boilerPlateContent" type="string">
<column name="boiler_plate_content" length="20" />
</property>
<property name="insertTime" type="date" insert="false">
<column name="insert_time_stamp"/>
</property>
<many-to-one class="Contracts" fetch="select" name="bt_contracts">
<column name="contract_id"/>
</many-to-one>
</class>
</hibernate-mapping>
配置文件的映射文件
<?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">
<hibernate-mapping default-access="field" package="com.catapult.bid.model">
<class name="Profiles" schema="bidtool" table="bid_tool_profiles">
<id column="profile_id" name="profileId" type="string">
<generator class="com.catapult.bid.commons.ProfileIDGenerator"/>
</id>
<many-to-one class="User" fetch="select" name="appUsers">
<column name="user_id"/>
</many-to-one>
<property name="profileContent" type="string">
<column name="profile_content"/>
</property>
<property name="scac" type="string">
<column length="20" name="scac"/>
</property>
<property name="created" type="timestamp" update="false">
<column name="insert_timestamp"/>
</property>
<property name="status" type="string">
<column length="9" name="status" not-null="true"/>
</property>
<property name="editable" type="string">
<column length="1" name="editable" not-null="true"/>
</property>
</class>
</hibernate-mapping>
答案 0 :(得分:2)
在这种情况下,你唯一能做的就是通过where子句进行内连接:
select a from A a, B b where a.someColumn = b.someOtherColumn and ...
只有使用HQL中的实体之间的关联才能实现正确的连接。
答案 1 :(得分:0)
您需要延迟获取Boiler_Plates(您的类不应在名称中包含下划线)和来自合同的配置文件。然后使用类似的东西:
select bp.contracts.profiles from Boiler_Plates bp where bp.boiler_plate_id=?
你的代码使用了太多的下划线,你也应该查看java编码约定:http://www.oracle.com/technetwork/java/codeconv-138413.html。