我正在使用dbunit创建数据库备份,这些备份可以导入和导出。我的应用程序可以使用几个数据库引擎:MySQL、PostgreSQL、SQLServer、H2和Oracle。
下面的代码可以很好地实现上述所有功能:
// Connect to the database
conn =BackupManager.getInstance().getConnection();
IDatabaseConnection connection = new DatabaseConnection(conn);
InputSource xmlSource = new InputSource(new FileInputStream(new File(nameXML)));
FlatXmlProducer flatXmlProducer = new FlatXmlProducer(xmlSource);
flatXmlProducer.setColumnSensing(true);
DatabaseOperation.CLEAN_INSERT.execute(connection,new FlatXmlDataSet(flatXmlProducer));
字符串
但是在Oracle上,我得到了这个例外:
!ENTRY es.giro.girlabel.backup 1 0 2012-04-11 11:51:40.542
!MESSAGE Start import backup
org.dbunit.database.AmbiguousTableNameException: AQ$_SCHEDULES
at org.dbunit.dataset.OrderedTableNameMap.add(OrderedTableNameMap.java:198)
at org.dbunit.database.DatabaseDataSet.initialize(DatabaseDataSet.java:231)
at org.dbunit.database.DatabaseDataSet.getTableMetaData(DatabaseDataSet.java:281)
at org.dbunit.operation.DeleteAllOperation.execute(DeleteAllOperation.java:109)
at org.dbunit.operation.CompositeOperation.execute(CompositeOperation.java:79)
at es.giro.girlabel.backup.ImportBackup.createData(ImportBackup.java:39)
at es.giro.girlabel.backup.handlers.Import.execute(Import.java:45)
型
6条答案
按热度按时间eivnm1vs1#
在DBUnit运行之前从Hibernate导入数据时,可能会遇到问题。根据所使用的数据库,表名和列名的大小写可能很重要。
例如,在HSQL中,数据库名称必须以大写形式声明。如果您通过Hibernate的import.sql导入数据,请确保表名也是大写的,否则将出现以下问题:
记住还要检查在上一次运行期间是否创建了多个表(大写和小写),在这种情况下,您还需要清理它。
gzszwxb42#
对我来说,Oracle工作简单的创建模式与一些特权,而不是所有或DBA。Dbunit停止了与其他架构中的表的冲突。
字符串
l7mqbcuq3#
关于docs:
第一个月
当可以访问多个具有相同名称的表时,
IDataSet
会引发此异常。当数据库连接可以访问包含相同表名的多个模式时,通常会发生这种情况。可能的解决方案:
1)使用只能访问一个数据库架构的数据库连接凭据。
2)为
DatabaseConnection
或DatabaseDataSourceConnection
构造函数指定架构名称。3)启用限定表名支持(请参见How-to文档)。
rslzwgfq4#
使用SpringDBUnit的人。我一直在努力解决这个非常棘手的问题。我最终通过添加
com.github.springtestdbunit.bean.DatabaseConfigBean
和com.github.springtestdbunit.bean.DatabaseDataSourceConnectionFactoryBean
的配置解决了这个问题。这是SpringDBUnit的完整Spring上下文
字符串
jgovgodb5#
设置数据库模式为我修复了它:
字符串
1mrurvl16#
我在对Oracle DB执行Dbunits时遇到了同样的AmbiguousTableNameException。它工作得很好,有一天开始抛出错误。
根本原因:在调用存储过程时,错误地将其修改为小写。当改变为大写时,它开始工作。
我还可以通过将shema名称设置为IDatabaseTester来解决这个问题,比如iDatabaseTester.setSchema(“SCHEMANAMEINCAPS”)
另外,请确保您的连接不会只访问具有相同表名的多个模式。