Hibernate逆向工程创建集(复合键)

时间:2014-10-02 17:19:51

标签: java mysql hibernate reverse-engineering composite-key

我无法让Hibernate将MySQL数据库正确地反向工程为Java类。

我有3张桌子:

  • 部门(pk = dept_no)
  • 员工(pk = emp_no)
  • dept_emp(composite pks dept_no and emp_no)

我正在尝试修改Hibernate Reverse Engineering文件以强制生成的DeptEmp Java类将单个部门链接到该部门内的一组员工,但我仍然遇到相同的错误,即使我已声明了集的名称属性:

org.hibernate.MappingException: Could not configure overrides from file: C:\lib\workspace\Hibernate Analysis 2\resources\hibernate.reveng.xml
Could not configure overrides from file: C:\lib\workspace\Hibernate Analysis 2\resources\hibernate.reveng.xml
org.hibernate.MappingException: Could not configure overrides from file: C:\lib\workspace\Hibernate Analysis 2\resources\hibernate.reveng.xml
Could not configure overrides from file: C:\lib\workspace\Hibernate Analysis 2\resources\hibernate.reveng.xml
org.hibernate.MappingException: invalid override definition
invalid override definition
org.xml.sax.SAXParseException; lineNumber: 10; columnNumber: 88; Attribute "name" must be declared for element type "set".
Attribute "name" must be declared for element type "set".

我的逆向工程文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-reverse-engineering PUBLIC "-//Hibernate/Hibernate Reverse Engineering DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-reverse-engineering-3.0.dtd" >

<hibernate-reverse-engineering>
    <table-filter match-catalog="employees" match-name="departments" />
    <table-filter match-catalog="employees" match-name="employees" />
    <table-filter match-catalog="employees" match-name="dept_emp" />

    <table name="dept_emp" class="com.DeptEmp">
        <set name="employeesSet" table="employees" inverse="true" lazy="true" fetch="select">
            <key>
                <column name="dept_no" ></column>
            </key>
            <one-to-many class="com.Employees"></one-to-many>
        </set>
    </table>
</hibernate-reverse-engineering>

我的Hibernate配置:

<?xml version="1.0" encoding="UTF-8"?>
<!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.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/employees</property>
        <property name="hibernate.connection.username">****</property>
        <property name="hibernate.connection.password">****</property>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        <property name="hibernate.default_catalog">employees</property>
        <property name="connection.pool_size">20</property>
        <property name="current_session_context_class">thread</property>
        <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
        <property name="show_sql">true</property>
        <property name="format_sql">true</property>
        <property name="use_sql_comments">true</property>

    </session-factory>
</hibernate-configuration>

0 个答案:

没有答案