我是 Java 和 Hibernate 的新手(虽然我熟悉实体框架,所以了解很多概念)
我要做的就是创建一个OrganisationNode
具有以下字段的表Id
:Name
和ParentId
ParentId
是 Nullable 并且,如果存在,应该指向一个有效的OranisationNode.Id
.
我认为这应该相当简单,但是花了 2 多天的时间在谷歌上搜索和编辑 XML 文件,我开始失去耐心。
让我从代码片段开始......
组织节点.java
@javax.persistence.Entity
public class OrganisationNode extends EntityBase implements Serializable {
private String name;
@ManyToOne(targetEntity = OrganisationNode.class, optional = true)
@JoinColumn(name="ParentId", referencedColumnName="Id") //This is one example of this attribute. I've tried many combinations
private OrganisationNode parent;
@OneToMany
private Set<OrganisationNode> children = new HashSet<OrganisationNode>();
//Getters/Setters
}
EntityBase.java
@javax.persistence.Entity
public class EntityBase implements Serializable {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private Long id;
//Getter/Setter
}
休眠.config.xml
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://mysqldev:3306/SomeDb?zeroDateTimeBehavior=convertToNull</property>
<property name="hibernate.connection.username">SomeUser</property>
<property name="hibernate.connection.password">SomePass!</property>
<property name="hibernate.hbm2ddl.auto">create</property>
<property name="show_sql">true</property>
<mapping resource="hibernate.hbm.xml"/>
</session-factory>
</hibernate-configuration>
休眠.hbm.xml
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.overshare.document.entities.OrganisationNode" table="OrganisationNodes">
<id name="id"><generator class="native"/></id>
<property name="name"/>
<property name="children"/>
<property name="parent"/>
</class>
</hibernate-mapping>
HibernateUtil.java
public class HibernateUtil {
private static SessionFactory sessionFactory;
public static void configureSessionFactory() {
Configuration configuration = new Configuration();
configuration.configure("hibernate.cfg.xml");
ServiceRegistryBuilder serviceRegistryBuilder = new ServiceRegistryBuilder().applySettings(configuration.getProperties());
sessionFactory = configuration.buildSessionFactory(serviceRegistryBuilder.buildServiceRegistry());
}
public static SessionFactory getSessionFactory() {
if(sessionFactory == null){configureSessionFactory();}
return sessionFactory;
}
}
我目前得到的例外是......
javax.servlet.ServletException:org.hibernate.MappingException:无法确定类型:java.util.Set,在表:OrganisationNodes,列:[org.hibernate.mapping.Column(Children)]
所以,我的第一个问题是如何解决这个异常?我相信我已经明确告诉它Children
应该指向什么。
我的下一个问题是……这一切真的有必要吗?我很难相信在 ORM 上建立并运行一个表需要这么多的配置和代码。我在这里得到的大部分内容都是从网络上的各种示例中窃取的,所以我不确定质量。当然,90% 的信息必须可以通过反射来休眠?