该帖已经被评为隐藏帖
|
|
---|---|
作者 | 正文 |
发表时间:2009-09-03
最后修改:2009-09-04
@Deprecated 此方法已经out了,很多ORM框架都支持。
最近一段时间在玩GAE,最终因为Bug太多,有些貌似BigTable的硬伤,所以就放弃之。 我对datanuclues也没做什么研究,只是发现它的一个特性:可以自动帮你的Entity在数据库中生成对应的表。完全自动,不依靠插件。(我记得hibernate做这个事情,好像是要依赖hibernate tools吧?还是我已经火星了?呵呵)
这里来一个3个实体的例子(这种关系GAE目前还不支持 *&@#): B many-to-one A C many-to-one A C many-to-one B 使用datanuleus就只需要直接写出实体类,是不是很方便呢? package org.datanucleus.samples.jdo.tutorial; import java.util.List; import javax.jdo.annotations.IdGeneratorStrategy; import javax.jdo.annotations.Join; import javax.jdo.annotations.PersistenceCapable; import javax.jdo.annotations.Persistent; import javax.jdo.annotations.PrimaryKey; @PersistenceCapable public class A { @PrimaryKey @Persistent(valueStrategy = IdGeneratorStrategy.INCREMENT) private Long id; private String name; @Join(column="A_B") private List<B> bList; @Join(column="A_C") private List<C> cList; //...get & set method } package org.datanucleus.samples.jdo.tutorial; import java.util.List; import javax.jdo.annotations.IdGeneratorStrategy; import javax.jdo.annotations.PersistenceCapable; import javax.jdo.annotations.Persistent; import javax.jdo.annotations.PrimaryKey; @PersistenceCapable public class B { @PrimaryKey @Persistent(valueStrategy = IdGeneratorStrategy.INCREMENT) private Long id; private String name; private List<C> cList; //...get & set method } package org.datanucleus.samples.jdo.tutorial; import javax.jdo.annotations.IdGeneratorStrategy; import javax.jdo.annotations.PersistenceCapable; import javax.jdo.annotations.Persistent; import javax.jdo.annotations.PrimaryKey; @PersistenceCapable public class C { @PrimaryKey @Persistent(valueStrategy = IdGeneratorStrategy.INCREMENT) private Long id; private String name; //...get & set method }
至于datanuclues 大家有兴趣的就到http://www.datanucleus.org/ 去了解吧。 本来想放上一个测试程序,但是依赖的jar太多就免去了。
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-09-03
hibernate不需要hibernate tools,SchemaExport就可以
|
|
返回顶楼 | |
发表时间:2009-09-03
最后修改:2009-09-03
Hibernate本身就支持数据库自动生成。其他的如TopLink、OpenJPA等ORM均支持自动生成数据库表。不过Hibernate的依赖库确实是所有ORM中最多的,不过好像自己配的话,有很多库都是可选的。
JDO其实是Java最早的ORM标准。当时EJB的持久Bean开发很麻烦,纯JDBC不够对象化。Sun就推出了JDO标准,但是一直没流行开。 |
|
返回顶楼 | |
发表时间:2009-09-03
最后修改:2009-09-03
谢谢猫咪~ 请问一下你提到的几个ORM框架生成表需要手动操作吗?
datanuleus只要程序运行,如果你没有指定表它就会在运行时自动帮你生成. 呵呵 我已经out了 |
|
返回顶楼 | |
发表时间:2009-09-03
自动生成表这个好像所有的JPA实现都可以哦
虽然没仔细看JPA的规范 但是感觉这个是规范的一部分来的 |
|
返回顶楼 | |
发表时间:2009-09-03
以前没用过这个特性,这样的话这篇帖子确实没啥价值了
|
|
返回顶楼 | |
发表时间:2009-09-03
最后修改:2009-09-03
solonote 写道 谢谢猫咪~ 请问一下你提到的几个ORM框架生成表需要手动操作吗?
datanuleus只要程序运行,如果你没有指定表它就会在运行时自动帮你生成. 呵呵 我已经out了 从这个问题可以看出,你是不是没有研究过其他orm? 不知道的东西不要妄自猜测. |
|
返回顶楼 | |
发表时间:2009-09-03
herowzz 写道 solonote 写道 谢谢猫咪~ 请问一下你提到的几个ORM框架生成表需要手动操作吗?
datanuleus只要程序运行,如果你没有指定表它就会在运行时自动帮你生成. 呵呵 我已经out了 从这个问题可以看出,你是不是没有研究过其他orm? 不知道的东西不要妄自猜测. 谢谢,请投隐藏贴 |
|
返回顶楼 | |
发表时间:2009-09-03
如果只能自动生成表的话,你落后了,hibernate自己就可以,只需要再配置文件中配置一两个选项就可以了
|
|
返回顶楼 | |
发表时间:2009-09-03
hibernate属性:
## auto schema export #hibernate.hbm2ddl.auto create-drop #hibernate.hbm2ddl.auto create #hibernate.hbm2ddl.auto update #hibernate.hbm2ddl.auto validate |
|
返回顶楼 | |