Сопоставление двух или более файлов hibernate hbm с одним классом Java Pojo
Файл hbm.xml для таблицы A, чей класс pojo в MyClass
<class name="com.entities.MyClass" table="A" entity-name="tableOne">
<id name="id" access="field" type="java.lang.Long">
<column name="ID" />
<generator class="increment" />
</id>
<property name="columnOne" type="java.lang.String">
<column name="COLUMN_ONE" />
</property>
<property name="columnTwo" type="java.lang.String">
<column name="COLUMN_TWO" />
</property>
</class>
файл hbm.xml для таблицы B (он также имеет тот же класс pojo "MyClass")
<class name="com.entities.MyClass" table="B" entity-name="tableTwo">
<id name="id" access="field" type="java.lang.Long">
<column name="ID" />
<generator class="increment" />
</id>
<property name="columnOne" type="java.lang.String">
<column name="COLUMN_ONE" />
</property>
<property name="columnTwo" type="java.lang.String">
<column name="COLUMN_TWO" />
</property>
</class>
это класс POJO
package com.entities;
public class MyClass{
Long id;
String columnOne;
String columnTwo;
public MyClass() {
// TODO Auto-generated constructor stub
}
public MyClass(Long id, String columnOne, String columnTwo) {
super();
this.id = id;
this.columnOne = columnOne;
this.columnTwo = columnTwo;
}
/**
* @return the id
*/
public Long getId() {
return id;
}
/**
* @param id the id to set
*/
public void setId(Long id) {
this.id = id;
}
/**
* @return the columnOne
*/
public String getColumnOne() {
return columnOne;
}
/**
* @param columnOne the columnOne to set
*/
public void setColumnOne(String columnOne) {
this.columnOne = columnOne;
}
/**
* @return the columnTwo
*/
public String getColumnTwo() {
return columnTwo;
}
/**
* @param columnTwo the columnTwo to set
*/
public void setColumnTwo(String columnTwo) {
this.columnTwo = columnTwo;
}
}
Как я могу вставить в таблицы? Я попробовал следующий код:
session.save("tableOne",myClassObj);
transaction.commit();
но при фиксации выдает следующее исключение
Hibernate: select max(ID) from A
org.hibernate.MappingException: Unknown entity: com.entities.MyClass
1 ответ
Вы можете использовать по имени таблицы следующим образом
session.save("A",myClassObj);
transaction.commit();