在开发使用Hibernate框架应用程序中,无外乎要创建hibernate.cfg.xml,xxx.hbm.xml,pojos和databaseSchema这些文件,框架这东西刚开始学会的时候,都是心情舒畅,热情高涨,所有文件都是自己手写不管这样重复性的工作有多么的乏味,爱情都会由低潮期更别说重复Coding了,久而久之在编写一个个xml、pojo和schema的过程中,不由从心中产生一种不舒畅之气。我曾经有一段时间见到代码文件就有想吐的冲动,不过还好我还是挺过来,嘛也就是像爱情麻木期一样,怎么都无所谓了。直到最近了解到Ant这个工具,让我看到了另一种发开Hibernate应用程序的方式,并不是说这样的开发方式就一定好于纯手工编写,适合自己才是最好的,但我是一个比较爱偷懒的,自动化构建非常的吸引我。开头字数凑够了就进入正题了,首先直接上build.xml,这个文件是ant所需要的
<?xml version="1.0" encoding="UTF-8"?>
<project name="hibernatetools" basedir="." default="useHibernateTool">
<!-- 导入build.properties文件,该文件定义一些常量,这些常量也可以是用<property name="" value="">的形式定义 -->
<property file="build.properties"></property>
<!-- 定义依赖包所在的位置,"${reference_libs_dir}"表示引用名为"reference_libs_dir"的常量 -->
<path id="referencelib">
<fileset dir="${reference_libs_dir}">
<!-- 匹配模式,表示该目录下所有jar文件 -->
<include name="**/*.jar"/>
</fileset>
</path>
<!-- 自定义Ant Task,但是使用的自定义类为Hibernate为我们提供的 -->
<taskdef name="hibernatetool" classname="org.hibernate.tool.ant.HibernateToolTask" classpathref="referencelib"></taskdef>
<!-- 使用hibernatetool -->
<target name="useHibernateTool">
<hibernatetool>
<!-- 指定资源搜索位置 -->
<classpath>
<path location="${source_folder_dir}"></path>
<path location="bin"></path>
</classpath>
<!-- 指定Hibernate的配置文件 -->
<configuration configurationfile="${source_folder_dir}/hibernate.cfg.xml"/>
<!-- 根据hbm生成java代码 -->
<hbm2java jdk5="true" destdir="${source_folder_dir}"/>
<!-- 根据hbm生成databaseSchema -->
<hbm2ddl destdir="${database_schema_dir}" export="true" outputfilename="sqlStatement.sql" format="true"/>
</hibernatetool>
</target>
</project>
build.properties文件:
source_folder_dir=src
reference_libs_dir=referencelibs
database_schema_dir=dbschema
这是项目最开始的状态:
此时项目中仅仅只是定义了cfg和hbm文件,数据库schema和pojo都没有定义,"referencelibs"中存放的是该程序要成功需要的依赖库文件。运行Ant,此时项目的状态:
可以看到,我们的需要的pojo类和schema都生成好了,其实按照我的build.xml设置,数据库已经直接设置到了两张表了。验证器正确性:
Customer.hbm.xml:
<?xml version="1.0" encoding="utf-8"?>
<!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.beliefbetrayal.hibernate.pojos.Customer" table="customer">
<!-- 主键设置 -->
<id name="id" type="string">
<column name="id"></column>
<generator class="uuid"></generator>
</id>
<!-- 属性设置 -->
<property name="username" column="username" type="string"></property>
<property name="balance" column="balance" type="integer"></property>
<set name="orders" inverse="true" cascade="all">
<key column="customer_id" ></key>
<one-to-many class="com.beliefbetrayal.hibernate.pojos.Order"/>
</set>
</class>
</hibernate-mapping>
Customer.java
package com.beliefbetrayal.hibernate.pojos;
// Generated 2012-2-8 1:10:59 by Hibernate Tools 3.3.0.GA
import java.util.HashSet;
import java.util.Set;
/**
* Customer generated by hbm2java
*/
public class Customer implements java.io.Serializable {
private String id;
private String username;
private Integer balance;
private Set<Order> orders = new HashSet<Order>(0);
public Customer() {
}
public Customer(String username, Integer balance, Set<Order> orders) {
this.username = username;
this.balance = balance;
this.orders = orders;
}
public String getId() {
return this.id;
}
public void setId(String id) {
this.id = id;
}
public String getUsername() {
return this.username;
}
public void setUsername(String username) {
this.username = username;
}
public Integer getBalance() {
return this.balance;
}
public void setBalance(Integer balance) {
this.balance = balance;
}
public Set<Order> getOrders() {
return this.orders;
}
public void setOrders(Set<Order> orders) {
this.orders = orders;
}
}
可以看到,我们借助Ant生成的POJO完全没问题。看看数据库Schema:
create table customer (
id varchar(255) not null,
username varchar(255),
balance integer,
primary key (id)
);
create table orders (
id varchar(255) not null,
orderNumber varchar(255),
cost integer,
customer_id varchar(255),
primary key (id)
);
alter table orders
add index FKC3DF62E51E0069B1 (customer_id),
add constraint FKC3DF62E51E0069B1
foreign key (customer_id)
references customer (id);
使用Ant自动化开发Hibernate需要hibernate-tools.jar包。我将项目整理了一下可以下载参考项目下载。