Вопрос по – Объединение двух несвязанных таблиц в спящем режиме

1

Есть ли способ, которым мы можем объединить две таблицы без прямой связи между ними, но иметь два общих поля в спящем режиме?

У меня есть две таблицы с именемiler_plates и профилем, между которыми нет прямой связи, но есть общее поле с именем contract_id.

Я написал запрос из профилей внутреннего соединения Boiler_Plates bp p на bp.bt_contracts = p.contract_id & quot; но он продолжает выдавать ошибку. & Quot; неожиданный токен: около строки 1, столбец 75 [из com.catapult.bid.model.Boiler_Plates как внутреннее соединение bp Профили как p для bp.bt_contracts = p.contract_id где bp.bt_contracts = 1] & quot ;.

Ниже приведен файл отображения гибернации для кипятильников и профилей.

Файл отображения для кипятильников.

<?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>

Ваш Ответ

2   ответа
2

что вы можете сделать в таком случае, это выполнить внутреннее соединение с помощью предложения where:

select a from A a, B b where a.someColumn = b.someOtherColumn and ...

Правильные объединения возможны только при использовании связей между сущностями в HQL

Но это вызовет CROSS JOIN в сгенерированном SQL!
0

подчеркивания в имени) и Profiles from Contracts. Затем используйте что-то вроде:

select bp.contracts.profiles from Boiler_Plates bp where bp.boiler_plate_id=?

В вашем коде слишком много подчеркиваний, вам следует также ознакомиться с соглашениями о кодировке Java:http://www.oracle.com/technetwork/java/codeconv-138413.html.

Похожие вопросы