以SQL Server配置Middlegen和extensions产生hbm和POJO

1、 所使用的软件及其版本如下:

ant-1.6.5

Middlegen-Hibernate-r5

hibernate-extensions-2.1

hibernate-2.1.6

以上均解压到D盘



2、 配置ant

将ant考到D:根目录
环境变量里加上ANT_HOME=D:\\ant

PATH=D:\\ant\\bin;
在DOS命令行下输入ant, 如果出现如下提示,就说明ant已配置成功了:

Buildfile: build.xml does not exist!
Build failed



3、 配置Middlegen-Hibernate:

3.1 配置mssql.xml文件,此文件用来配置SQL Server数据库连接

将SQL Server三个jar文件(mssqlserver.jar; msbase.jar; msutil.jar)copy到Middlegen-Hibernate-r5\lib目录中。

在Middlegen-Hibernate-r5\config\database目录中有一个mssql.xml文件,是用来配置SQL Server数据库的连接的。内容修改如下(红色为修改部分)为:

<property name="database.script.file" value="${src.dir}/sql/${name}-[color=red]mssql.sql[/color]"/>

<property name="database.driver.file" value="${lib.dir}/[color=red]mssqlserver.jar[/color]"/>

<property name="database.driver" value="[color=red]com.microsoft.jdbc.sqlserver.SQLServerDriver[/color]"/>

<!—粗体部分的结构为: //数据库服务器名或IP;database=要操作的数据库名 -->

<property name="database.url" value="[color=red]jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=Northwind[/color]"/>

<property name="database.userid" value="[color=red]admin[/color]"/>

<property name="database.password" value="[color=red]admin[/color]"/>

<!-- In MS SQL database.schama is the owner of the tables as displayed by SQL Server Enterprise Manager -->

<property name="database.schema" value="[color=red]dbo[/color]"/>

<!-- In MS SQL database.catalog is the name of database such as 'Northwind' -->

<property name="database.catalog" value=" [color=red]Northwind[/color]"/>

<property name="jboss.datasource.mapping" value="MS SQLSERVER"/>



3.2 配置Middlegen-Hibernate-r5的ant运行文件build.xml

<!DOCTYPE project [

<!ENTITY database SYSTEM "file:./config/database/[color=red]mssql.xml[/color]">

]>

指出使用的数据库配置文件。

<project name="Middlegen Hibernate" default="all" basedir=".">

<property file="${basedir}/build.properties"/>

<property name="name" value="sample"/>

指出生成的*.hbm.xml输出的路径:

<property name="build.gen-src.dir" value="[color=red]C:/sample[/color]"/>

配置hibernate:

<hibernate

destination="${build.gen-src.dir}"

package="[color=red]org.hibernate.sample[/color]" ——————指出hbm所在的包的位置。

genXDocletTags="[color=red]true[/color]" ——————指出hbm.xml中是否需要XDoclet Tags。

genIntergratedCompositeKeys="false"

javaTypeMapper="middlegen.plugins.hibernate.HibernateJavaTypeMapper"

/>

配置Middlegen:

<middlegen

appname="${name}"

prefsdir="${src.dir}"

gui="${gui}"

databaseurl="${database.url}"

initialContextFactory="${java.naming.factory.initial}"

providerURL="${java.naming.provider.url}"

datasourceJNDIName="${datasource.jndi.name}"

driver="${database.driver}"

username="${database.userid}"

password="${database.password}"

schema="${database.schema}"

catalog="${database.catalog}"

[color=red] includeViews="true"——————[/color]指出包括视图。

>



4、 运行Middlegen-Hibernate:

在Middlegen-Hibernate目录下运行ant,进入Middlegen-Hibernate的图形界面。可以设置表,和字段的特性。然后按Genarate,产生hbm.xml文件。



5、 配置hibernate-extensions

5.1 在hibernate-extensions\tools\bin目录下有3个工具,他们的功能如下:

5.1.1 class2hbm.bat

根据POJO class 生成映射文件

也就是根据你自己对应表所写的java文件,生成相应的*.hbm.xml文件;


5.1.2 ddl2hbm.bat

由数据库导出库表结构,并生成映射文件以及POJO。这个功能与MiddleGen 的功能重叠,也不够成熟(实际上已经被废弃,不再维护);


5.1.3 hbm2java.bat

根据映射文件生成对应的POJO,即根据Middlegen生成的*.hbm.xml文件再生成相应的*.java文件



5.2 在hibernate-extensions-2.1.2\tools\bin目录有一个setenv.bat文件,改变其内容为:

set JDBC_DRIVER=[color=red]D:\Middlegen-Hibernate-r5\lib\mssqlserver.jar[/color]

set HIBERNATE_HOME[color=red]=..\..\hibernate-2.1.6[/color]
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



6、 运行hibernate-extensions,根据hbm.xml产生POJO文件

在DOS中运行hbm2java c:\sample\org\hibernate\sample\*.xml --output=c:\sample\
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值