您的位置:首页 > 编程语言 > Java开发

(转) Eclipse通过HibernateTools实现逆向生成Hibernate实体类

2017-09-08 16:54 429 查看
背景:工作中使用Hibernate进行持久化的开发工作,所以有必要详细了解这方面的知识。

在项目开发时,要么先完成数据库表的设计,再逆向生成实体类或者根据需求分析建立实体类,有正向生成数据库表。没有人会浪费大量的时间在进行完任意一方时自己匹配建立另一方设计,这样做还可能导致两边映射不一致,对开发和维护都不利。废话不多说,现在开始实现由数据库逆向生成Hibernate实体类的方法。

1 Eclipse配置Hibernate环境

(1)HibernateTools下载地址:http://download.csdn.net/detail/b671900/7884405

(2)解压后将features和plugins这两个文件夹拷贝到我们事先建好的文件夹eclipse-jee-luna-R\MyPlugins\HibernateTools\下面。如下图所示

:


(3)在eclipse目录新建目录links(如果已经存在就不需要在创建了),在该目录下新建文件hibernate.link,内容为:path=D:/eclipse-jee-luna-R/MyPlugins/Hibernatetools



(4)重新启动Eclipse,在文件(file)-->新建(new)-->其它(other)中如果看到hibernate的配置项就证明已经安装成功,如下图:



2 创建项目生成映射文件和持久化类

(1)新建一个项目hibernateTools,并将数据库驱动拷贝到lib目录下,项目的目录结构如下:



ps:这里我根据需要使用oracle的jar包。这里可以随意建一个工程,或者使用系统工程,只要jar包存在即可。

2.1 打开Hibernate Perspective视图层

在Eclipse中打开“Hibernate Perspective“。

选择“Windows” >> “Open Perspective” >> “Others…” , 选择 “Hibernate“。

2.2 新建Hibernate Configuration 配置

1.在Hibernate Perspective中, 右键,选 “Add Configuration…”,弹出对话框

2.在 “Project”区域, 单击 “Browse..” 选择你自己的项目。(根据具体情况作出判断)
3.在 “Database Connection” 区域, 单击 “New..”创建你自己的数据库设定。



4.弹出Connection Profile中选Oracle ,并填写“Name”后,Next



5.在弹出对话框中,选Driver,没有的话要新加,此处新加Driver。



6.弹出对话框中选一个driver,如果出现“Unable to locate JAR/zip in file system as specified by the driver definition: ojdbc14.jar.”

就要在“JAR List”选项卡中删除原有的驱动文件,重新加一下就好了。



ps:这里的Driver name 自己命名,后面可以直接选取

删除驱动文件重新添加,此处添加的是Maven仓库中的jar包



完成后点击OK

ps:此处要配置前边的jar包路径



填写完数据库的相关连接后,可以点Test Connection测试是否可以连接上。



连接上如图



7.Configuration file配置

ps:下面的Database connections选项选择第6步中配置好的连接名称。如下所示



点击“Setup”弹出“Setup configuration file”对话框,如果不存在.dfg.xml文件,可以新建



上图点击“Create New...”后,弹出新建cfg.xml文件对话框

创建在项目目录下的main/java/resources下,

我的是在“maven-hibernate-demo/src/main/resources”

可以点击next配置更具体的设置,此处我们直接Finsh



返回前一界面后,OK。记住,此处的“Hibernate Version”选项一定要选对版本,否则反向工程不会成功。



查看Hibernate Configurations视图

ps:这个过程会有点长,如下图所示



2.3 查看src/main/resources目录下的刚建好的hibernate.cfg.xml文件

ps:这里可以自己写,也可以直接finish跳过

<?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">oracle.jdbc.OracleDriver</property>
<property name="hibernate.connection.password">password</property>
<property name="hibernate.connection.url">jdbc:oracle:thin:@yourdatabaseip:gzip</property>
<property name="hibernate.connection.username">username</property>
<property name="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</property>
</session-factory>
</hibernate-configuration>


2.4 生成Hibernate代码

在“Hibernate Perspective”视图中, 点击 “Hibernate Code Generation Configuration”



在生成代码框中,新建configuration,并填写Main选项卡和Exporters选项卡,

Main中需要填写输出路径等,填完的如下

console configuration选择前边刚配置完的Hibernate Configuration,前边的名字是“hibernate”

Output directory选择输出路径

Reverse enginner from JDBC Connection勾选

Package填写包名

reveng.xml填写创建hibernate.reveng.xml的位置,没有则新建。



console configuration:选择在第二点中我们创建的数据库连接。

output directory:配置执行后输出的目录,生成hbm、PO类等。

package:包名,这里请输入PO类存放的路径。

reveng.xml:生成mapping和PO类的重要配置文件

ps:在创建reveng.xml时候,要点击next,配置需要进行映射的数据库表。





ps:此处刷新有点缓慢,选择要进行映射的数据表即可。



在Exporters选择相应要生成的代码

可以生成Model , mapping file (hbm) , DAO, annotation code 等等。



点Run生成代码

生成的代码结构如下

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: