Java 甲骨文+;dbunit获取含糊不清的UstableNameException
我使用dbunit创建数据库备份,可以导入和导出。我的应用程序可以使用几个数据库引擎:MySQL、PostgreSQL、SQLServer、H2和Oracle 使用以下代码,上述所有操作都可以正常工作:Java 甲骨文+;dbunit获取含糊不清的UstableNameException,java,sql,database,oracle,dbunit,Java,Sql,Database,Oracle,Dbunit,我使用dbunit创建数据库备份,可以导入和导出。我的应用程序可以使用几个数据库引擎:MySQL、PostgreSQL、SQLServer、H2和Oracle 使用以下代码,上述所有操作都可以正常工作: // Connect to the database conn =BackupManager.getInstance().getConnection(); IDatabaseConnection connection = new Data
// 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)
从:
公共类AmbiguoCustomableNameException扩展了DataSetException
当多个表具有
可以访问相同的名称。这通常发生在数据库
连接可以访问包含相同表的多个架构
名字
可能的解决办法:
1) 使用具有以下权限的数据库连接凭据:
只能访问一个数据库架构
2) 将架构名称指定给
数据库连接
或数据库数据源连接
构造函数
3) 启用限定表名支持(请参见如何使用文档)
为谁使用SpringDBUnit。我一直在努力解决这个非常烦人的问题。我最终解决了这个问题,添加了
com.github.springtestdbunit.bean.DatabaseConfigBean
和com.github.springtestdbunit.bean.DatabaseDataSourceConnectionFactoryBean
的配置
这是SpringDBUnit的完整spring上下文
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@localhost:1521/XE" />
<property name="username" value="xxxx" />
<property name="password" value="xxxx" />
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
<property name="annotatedClasses">
<list>
<value>xxx.example.domain.Person</value>
</list>
</property>
</bean>
<bean id="dbUnitDatabaseConfig" class="com.github.springtestdbunit.bean.DatabaseConfigBean">
<property name="skipOracleRecyclebinTables" value="true" />
<property name="qualifiedTableNames" value="true" />
<!-- <property name="caseSensitiveTableNames" value="true"/> -->
</bean>
<bean id="dbUnitDatabaseConnection"
class="com.github.springtestdbunit.bean.DatabaseDataSourceConnectionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="databaseConfig" ref="dbUnitDatabaseConfig" />
<property name="schema" value="<your_schema_name>"/>
</bean>
org.hibernate.dialen.oraclealent
真的
xxx.example.domain.Person
在针对Oracle DB执行Dbunits时,我遇到了相同的含糊不清的自定义名称异常。它工作正常,有一天开始出错
根本原因:调用存储过程时,它被错误地修改为小写。当改为大写时,它开始工作
我也可以通过将shema名称设置为IDatabaseTester来解决这个问题,比如IDatabaseTester.setSchema(“SCHEMANAMEINCAPS”)
另外,请确保您的连接不会仅访问具有相同表名的多个架构。设置数据库架构为我修复了它:
@Bean
public DatabaseDataSourceConnectionFactoryBean dbUnitDatabaseConnection(final DataSource dataSource){
final DatabaseDataSourceConnectionFactoryBean connectionFactory = new DatabaseDataSourceConnectionFactoryBean();
connectionFactory.setDataSource(dataSource);
connectionFactory.setSchema(DB_SCHEMA);
return connectionFactory;
}
在DBUnit运行之前从Hibernate导入数据时,可能会遇到问题。根据您使用的数据库,表名和列名的大小写可能很重要 例如,在HSQL中,数据库名称必须以大写形式声明。 如果通过Hibernate的import.sql导入数据,请确保表名也是大写的,否则会出现以下问题:
- Hibernate以小写形式创建表
- DBUnit以小写形式从数据库中读取表名
- DBUnit尝试使用大写表名导入其数据集
- 你最终陷入了一片混乱,名字模棱两可
请记住还要检查在上一次运行期间是否创建了多个表(大写和小写),在这种情况下,您也需要清理它。谢谢,我已经解决了这个问题,但它是通过您提到的解决方案1实现的。我使用,解决方案1)可以通过设置系统属性来实现。我通过将
DatabaseConfigBean#setQualifiedTableNames
设置为true
来修复它。解决方案在本文中有更清楚的解释:。对于Spring JDBC,我必须这样做: