我使用Hibernate的SchemaUpdate来执行与迁移相同的function。 这实际上比迁移更容易,因为每次启动应用程序时,都会检查数据库结构并将其与映射进行同步,因此不需要额外的耙:db:migrate步骤,并且您的应用程序永远不会与正在运行的数据库不同步反对。 Hibernate映射文件不比Rails迁移复杂,所以即使你没有在应用中使用Hibernate,你也可以利用它。 不足之处在于它不如回滚,迁移,运行DML语句那样灵活。 正如在评论中指出的,它也不会删除表或列。 我运行一个单独的方法来手动执行这些操作,作为Hibernate初始化过程的一部分。
我不明白为什么你不能使用Rails迁移 – 只要你不介意安装栈(Ruby,Rake,Rails),你就不必触摸你的应用程序。
对于一个function之间的比较
迁飞
Liquibase
C5-DB-迁移
dbdeploy
MyBatis的
MIGRATEdb
migrate4j
dbmaintain
AutoPatch
这对于您和其他人来说是一个好的开始,可以为工作select正确的工具
Liquibase是这个领域的另一个值得检查的项目。
Grails有一个dbmigrate实用程序,它是Rails中的一个。 由于它是在Groovy中实现的,所以您应该可以从任何Java项目中使用它。
Java还有两个独立的rails类迁移实现:
1)基于Maven的Carbon Five迁移
2) Hashrocket基于Ant的任务(我个人最喜欢的)
虽然这些包是专门为Maven和Ant编写的,但有些工作可以使它们适应任何东西。
在研究同一个问题的时候,我跑过这个post。 我还没有得出任何关于最佳工具或方法的结论,但是到目前为止还没有被其他答案提及的一个工具是dbdeploy 。 我有兴趣阅读这些工具的任何比较。
其他一些相关资源:Martin Fowler和Pramod Sadalage在进化数据库devise方面有些过时了,还有Sadalage和Scot Ambler的“ 重构数据库:进化数据库devise ”一书。
Migrate4j似乎是一个候选人,但是这个项目对于生产使用来说看起来还不够成熟。
也有最初在Unitils内部开发的DbMaintain,但现在是一个专门的项目。 我们正在使用它,并且非常满意(这并不意味着没有任何好的select)。 我在我的数据库+迁移书签中列出了更多的内容(着重于支持Maven的工具)。