说明,此方法目前只适应与hibernate2.x版本,生成的.hbm.xml文件可能要做相应的修改才能适应hibernate3.2
步骤 :
1、配置环境
下载地址
(1)Middlegen-Hibernate-r5:http://prdownloads.sourceforge.net/hibernate/
(2)hibernate-2.1:http://prdownloads.sourceforge.net/hibernate/
(3)hibernate-extensions-2.1.3:http://prdownloads.sourceforge.net/hibernate/
保存如下目录结构:
d:\hibernate
|- hibernate-2.1
|- hibernate-extensions-2.1.3
|- Middlegen-Hibernate-r5
2、通过middlegen生成hbm.xml代码
2.1 配置数据库连接
假设连接的数据库是MySQL,在Middlegen-Hibernate-r5\config\database目录中有一个 mysql.xml文件,是用来配置MySQL数据库的连接的。内容为:
<property name="database.script.file" value="${src.dir}/sql/${name}-mysql.sql"/>
<property name="database.driver.file" value="${lib.dir}/mysql-connector-java-3.0.15-ga-bin.jar"/>
<property name="database.driver.classpath" value="${database.driver.file}"/>
<property name="database.driver" value="org.gjt.mm.mysql.Driver"/>
<property name="database.url" value="jdbc:mysql://localhost/jboss"/>
<property name="database.userid" value="jboss"/>
<property name="database.password" value="jboss"/>
<property name="database.schema" value=""/>
<property name="database.catalog" value=""/>
<property name="jboss.datasource.mapping" value="mySQL"/>
将mysql-connector-java-3.0.15-ga-bin.jar拷贝到${lib.dir},也就是Middlegen-Hibernate-r5\lib目录。
修改配置文件中的数据库连接项目database.url、database.userid、database.userid使Middlegen-Hibernate可以找到数据库。
2.2 配置Middlegen-Hibernate-r5的ant运行文件build.xml
<!DOCTYPE project [<!ENTITY database SYSTEM "file:./config/database/mysql.xml">]>
指出使用的数据库配置文件。
<project name="Middlegen Hibernate" default="all" basedir=".">
<property file="${basedir}/build.properties"/>
<property name="name" value="hibernatesample"/>
指出你的应用名称。
<property name="build.gen-src.dir" value="C:/sample"/>
指出hbm的输出路径。
<hibernate
destination="${build.gen-src.dir}"
package="org.hibernate.sample"
genXDocletTags="false"
genIntergratedCompositeKeys="false"
javaTypeMapper="middlegen.plugins.hibernate.HibernateJavaTypeMapper"
/>
指出hbm所在的包的位置。
指出hbm.xml中是否需要XDoclet Tags
2.3、 运行Middlegen-Hibernate:
在Middlegen-Hibernate目录下运行ant,进入Middlegen-Hibernate的图形界面。可以设置表,和字段的特性。然后按Genarate,产生hbm.xml文件。
3、通过hibernate-extensions由.hml.xml文件生成POJO文件
3.1、置hibernate-extensions
在hibernate-extensions-2.1.2\tools\bin目录有一个setenv.bat文件,改变其内容为:
set JDBC_DRIVER=C:\java\Middlegen-Hibernate-r5\lib\mysql-connector-java-3.0.15-ga-bin.jar
set HIBERNATE_HOME=C:\java\hibernate-2.1.6
set CORELIB=%HIBERNATE_HOME%\lib
set LIB=..\lib
set PROPS=%HIBERNATE_HOME%\src
set CP=%JDBC_DRIVER%;%PROPS%;%HIBERNATE_HOME%\hibernate2.jar;%CORELIB%\
commons-logging-1.0.4.jar;%CORELIB%\commons-collections-2.1.1.jar;%CORELIB%\
commons-lang-1.0.1.jar;%CORELIB%\cglib-full-2.0.2.jar;%CORELIB%\dom4j-1.4.jar;
%CORELIB%\odmg-3.0.jar;%CORELIB%\xml-apis.jar;%CORELIB%\xerces-2.4.0.jar;
%CORELIB%\xalan-2.4.0.jar;%LIB%\jdom.jar;%LIB%\..\hibernate-tools.jar
注意红色字体提示的均是路径和JAR文件名,一定要正确。
3.2、运行hibernate-extensions,根据hbm.xml产生POJO文件
在DOS中运行hbm2java c:\sample\org\hibernate\sample\*.xml 命令
在hibernate-extensions-2.1.2\tools\bin目录下生成generated目录即为生成的POJO代码