|
锁定老贴子 主题:Hibernate中代码自动生成功能小结
该帖已经被评为精华帖
|
|
|---|---|
| 作者 | 正文 |
|
时间:2003-09-15
Hibernate中需要class和mapping file, 也就是java文件和hbm.xml文件,由于Hibernate只支持DML, 不支持DDL,所以在DB中需要有DDL或已经存在的数据库的表。Hibernate中共有三种文件与代码自动生成功能有关:
class, mapping file and DDL 1. Middlegen 是用来从DB中已存在的表,生成相应的mapping file. 可以下载一个老外的middlegen的例子。 http://sourceforge.net/project/showfiles.php?group_id=40712 调用Middlegen很简单,例子中的middlegen自动生成ant指令如下 引用 <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}" > <hibernate destination="${build.gen-src.dir}" package="${name}.hibernate" /> </middlegen> 然后会有一个GUI,给我们专门设计各种表与表之间的关系(一对一,一对多以及单向双向关系)。需要说明的是,middlegen生成的代码没有直接写mapping file灵活性好,所以生成的mapping file有时还需要我们去修改。 2. XDoclet 它是用来从java文件自动生成hbm文件的,不过我们需要在java代码中写一些规定的tag,才能得到自动生成的hbm文件. [code:1] <hibernatedoclet destdir="src" excludedtags="@version,@author,@todo" force="true" verbose="true"> <fileset dir="src"> <include name="**/*.java"/> <exclude name="**/Product.java"/> </fileset> <hibernate version="2.0"/> </hibernatedoclet> [/code:1] 3. hbm2java 它是用来从mapping 文件生成java代码的工具,调用很简单,在参数中需要给出所有的hbm文件,如下: [code:1] <java classname="net.sf.hibernate.tool.hbm2java.CodeGenerator" fork="true"> <classpath refid="classpath"/> <arg line="${build.gen-src.dir}/airline/hibernate/*.hbm.xml"/> </java> [/code:1] 4. SchemaExport 如果写好了java文件和hbm文件,就可以用SchemaExport直接生成DDL文件,调用同样简单,只需在java代码中,加入如下: [code:1] conf = new Configuration() .addClass(a.class) .addClass(b.class); SchemaExport dbExport = new SchemaExport(conf); dbExport.setOutputFile("myschema.sql"); dbExport.create(true, true); [/code:1] 从这四种自动生成工具来看, mapping file, java file and DDL,只要知道任何一种文件,都可以得到另外两种文件, 如: 1. 只有mapping file: mapping file---hbm2java----java---SchemaExport----DDL 2.只有DDL DDL---Middlegen---hbm----hbm2java----java 3.只有Java java---XDoclet---hbm----SchemaExport----DDL 从这里,大家也可以体会到, Hibernate强大的灵活性。 声明:JavaEye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
|
|
| 返回顶楼 | |
|
时间:2003-09-16
顶一下,谢谢
|
|
| 返回顶楼 | |
|
时间:2003-09-16
推荐的做法是先写hbm,然后两头开花,用工具生成ddl和java。
但生成的ddl还是要修改的 |
|
| 返回顶楼 | |
|
时间:2003-10-24
个人习惯:
当对象多,字段多时,还是先建表.再生产HBM,再PO |
|
| 返回顶楼 | |
|
时间:2007-01-29
虽然先写POJO,再写出hbm,然后通过hbm生成相应的DDL显得比较OO,但生成的DDL要改的非常多,实在是~~~个人还是比较喜欢从表来生成相应的hbm,工具也比较多。
|
|
| 返回顶楼 | |
|
时间:2007-01-29
先生成表再XML吧。这样可靠性高一点点吧
|
|
| 返回顶楼 | |
|
时间:2007-01-30
用xdoclet,ant java - hbm - 表
|
|
| 返回顶楼 | |
|
时间:2007-03-29
从hibernate的角度出发,肯定是hbm最优先,所有配置信息都在hbm里面,有了hbm再上下生成java和ddl也比较方便(默认就有工具支持)。
不过问题的关键是,一般的OO/UML设计工具(如Together Rose 等)都是针对java进行的可视化的设计,生成的也是java代码。 好像没有工具支持可视化地设计HBM阿!(包括HBM间的关系图类图,正向反向工程支持等,类似Together/Rose对JAVA的支持)。 |
|
| 返回顶楼 | |
|
时间:2007-03-29
2003年的帖子都被刨出来了啊,现在用annotation
|
|
| 返回顶楼 | |
|
时间:2007-04-03
感觉annotation应该会比写xml省不少。 |
|
| 返回顶楼 | |










