使用DdlUtils和Ant进行不同数据库之间schema和data的转换
2011-10-08 01:05
411 查看
声明:使用DdlUtils需要基本的ant知识。
在开发过程中常常要用到多种数据库类型,比如项目可能需要支持Oracle, MySQL, MSSQL Server, Derby等等。已经有很多各种各样的小工具可以帮助开发人员进行数据库之间的schema、data转换与同步,DdlUtils 就是其中之一。它可以结合Ant或者程序代码进行数据库schema/data和xml文件的相互转换。
例如,项目开发支持的是MySQL,而为了单元测试的整洁和方便,开发人员决定使用Derby来支持单元测试。DdlUtils就可以把schema和数据从MySQL中导出,变成xml文件,然后根据需要导入到Derby中;反之亦可。显然,这些导出的xml文件也是对于数据库的一个很好的备份。
下面是apache ddlutils官网给出的一个xml的例子,table和column标签里面支持的child和attribute远不止示例中的这些。
DdlUtils包含了3个Ant Task,分别是databaseToDdl, ddlToDatabase以及dumpMetadata。
使用ddlToDatabase的示例:
这个Ant任务创建了一个PostgreSQL数据库,把xml中定义的schema和data导入到数据库中。
使用databaseToDdl的示例:
这个Ant任务把derby数据库中的schema和data导出到xml文件中。
在开发过程中常常要用到多种数据库类型,比如项目可能需要支持Oracle, MySQL, MSSQL Server, Derby等等。已经有很多各种各样的小工具可以帮助开发人员进行数据库之间的schema、data转换与同步,DdlUtils 就是其中之一。它可以结合Ant或者程序代码进行数据库schema/data和xml文件的相互转换。
例如,项目开发支持的是MySQL,而为了单元测试的整洁和方便,开发人员决定使用Derby来支持单元测试。DdlUtils就可以把schema和数据从MySQL中导出,变成xml文件,然后根据需要导入到Derby中;反之亦可。显然,这些导出的xml文件也是对于数据库的一个很好的备份。
下面是apache ddlutils官网给出的一个xml的例子,table和column标签里面支持的child和attribute远不止示例中的这些。
<?xml version="1.0"?> <!DOCTYPE database SYSTEM "http://db.apache.org/torque/dtd/database.dtd"> <database name="testdb"> <table name="author"> <column name="author_id" type="INTEGER" primaryKey="true" required="true"/> <column name="name" type="VARCHAR" size="50" required="true"/> <column name="organisation" type="VARCHAR" size="50" required="false"/> </table> <table name="book"> <column name="book_id" type="INTEGER" required="true" primaryKey="true" autoIncrement="true"/> <column name="isbn" type="VARCHAR" size="15" required="true"/> <column name="author_id" type="INTEGER" required="true"/> <column name="title" type="VARCHAR" size="255" defaultValue="N/A" required="true"/> <foreign-key foreignTable="author"> <reference local="author_id" foreign="author_id"/> </foreign-key> <index name="book_isbn"> <index-column name="isbn"/> </index> </table> </database>
DdlUtils包含了3个Ant Task,分别是databaseToDdl, ddlToDatabase以及dumpMetadata。
使用ddlToDatabase的示例:
这个Ant任务创建了一个PostgreSQL数据库,把xml中定义的schema和data导入到数据库中。
<path id="runtime-classpath"> <fileset dir="lib"> <include name="**/*.jar"/> <include name="**/*.zip"/> </fileset> </path> <target name="database-setup" description="Creates the database structure and inserts data into the database"> <taskdef name="ddlToDatabase" classname="org.apache.ddlutils.task.DdlToDatabaseTask"> <classpath refid="runtime-classpath"/> </taskdef> <ddlToDatabase> <database url="jdbc:postgresql://localhost/test" driverClassName="org.postgresql.Driver" username="someuser" password="somepassword"/> <fileset dir="src/schema"> <include name="project-schema.xml"/> </fileset> <createDatabase failonerror="false"/> <writeSchemaToDatabase/> <writeDataToDatabase datafile="src/data/data.xml"/> </ddlToDatabase> </target>
使用databaseToDdl的示例:
这个Ant任务把derby数据库中的schema和data导出到xml文件中。
<path id="runtime-classpath"> <fileset dir="lib"> <include name="**/*.jar"/> <include name="**/*.zip"/> </fileset> </path> <target name="database-dump" description="Dumps the database structure"> <taskdef name="databaseToDdl" classname="org.apache.ddlutils.task.DatabaseToDdlTask"> <classpath refid="runtime-classpath"/> </taskdef> <databaseToDdl modelName="MyModel"> <database url="jdbc:derby:ddlutils" driverClassName="org.apache.derby.jdbc.EmbeddedDriver" username="" password=""/> <writeSchemaToFile outputFile="db-schema.xml"/> <writeDataToFile outputFile="data.xml"/> </databaseToDdl> </target>
相关文章推荐
- SQL中相同两表,不同数据库之间进行数据库互导
- 如何使用PHP和PEAR进行不同时区的转换
- 使用json-lib进行Java和JSON之间的转换
- 使用DLL进行不同语言之间的调用
- android开发中使用Gson进行对象和Json之间的转换很方便
- 使用DLL进行不同语言之间的调用
- 使用Python内置的模块与函数进行不同进制的数的转换
- 使用OPENDATASOURCE和OPENROWSET在不同类型的数据库之间导入导出数据
- 使用XStream进行POJO和xml之间的转换
- linux shell+vim处理不同数据库文本之间的转换
- 使用XStream进行POJO和xml之间的转换
- 使用json-lib进行Java和JSON之间的转换
- 使用PowerDesigner的物理模型生成不同的数据库和转换成OOM模型生成CS实体类代码
- 如何使用ANT自动进行数据库的相关操作
- 使用json-lib进行Java和JSON之间的转换
- 接口实现不同数据库之间的转换
- 类型之间进行隐式和显示转换&创建使用枚举&创建使用结构类型&创建使用数组&;如何处理字符串值
- 使用json-lib进行Java和JSON之间的转换
- 如何使用ANT自动进行数据库的相关操作
- 使用json-lib进行Java和JSON之间的转换【转载】