DBUnit:NoSuchColumnException ColumnNameToIndexes 缓存映射中的非大写输入列。地图的列名不区分大小写
DBUnit: NoSuchColumnException Non-uppercase input column in ColumnNameToIndexes cache map. map's column names are NOT case sensitive
我的 java 应用程序将您的信息存储在 MySql 数据库版本 8 中。用户信息和密码存储在该数据库中。我正在实施一个集成测试来测试使用 dbunit 验证数据库中用户的方法。测试方法运行后出现如下错误
Caused by: org.dbunit.dataset.NoSuchColumnException: USER.USER_ID - (Non-uppercase input column: USER_ID) in ColumnNameToIndexes cache map. Note that the map's column names are NOT case sensitive.
我通过 MySql Workbench 检查 table 和列都是用大写字母创建的,因此显示的错误消息没有意义。有谁知道是什么导致了这个异常?
testContext.xml
unitils.properties
unitils.module.hibernate.enabled=true
unitils.module.jpa.enabled=false
unitils.module.easymock.enabled=false
database.url=jdbc:mysql://192.168.0.12:3306/db_ca?useUnicode=true&characterEncoding=UTF-8&serverTimezone=America/Sao_Paulo
database.driverClassName=com.mysql.jdbc.Driver
database.userName=root
database.password=9999
database.schemaNames=db_main, db_ca
database.dialect=mysql
unitils.module.database.className=com.myapplication.test.unitils.SingleConnectionDatabaseModule
DatabaseModule.Transactional.value.default=disabled
DbUnitModule.DataSet.loadStrategy.default=org.unitils.dbunit.datasetloadstrategy.impl.CleanInsertLoadStrategy
updateDataBaseSchema.enabled=true
dbMaintainer.script.locations=src/test/dbscripts
dbMaintainer.autoCreateExecutedScriptsTable=true
dbMaintainer.generateDataSetStructure.enabled=false
dbMaintainer.preserve.schemas=
在 src/test/dbscripts 中存在文件 001_SCRIPT_01.00.00
SET character_set_client = utf8mb4 ;
CREATE TABLE db_ca.ROLE (
ROLE_ID INT(11) NOT NULL AUTO_INCREMENT,
NAME VARCHAR(200) NOT NULL,
PRIMARY KEY (ROLE_ID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
SET character_set_client = utf8mb4 ;
CREATE TABLE db_ca.USER (
USER_ID INT(11) NOT NULL AUTO_INCREMENT,
EMAIL VARCHAR(100) NULL DEFAULT NULL,
NAME VARCHAR(150) NOT NULL,
PASSWORD VARCHAR(200) NOT NULL,
PRIMARY KEY (USER_ID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
SET character_set_client = utf8mb4 ;
CREATE TABLE db_ca.USER_ROLE (
ROLE_ID INT(11) NOT NULL,
USER_ID INT(11) NOT NULL,
PRIMARY KEY (ROLE_ID, USER_ID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
/datasets/UserServiceTest.xml
<?xml version="1.0" encoding="UTF-8"?>
<dataset xmlns="db_ca">
<USER
USER_ID = "1"
EMAIL = "test@test.com"
NAME = "TEST"
PASSWORD = "e8d95a51f3af4a3b134bf6bb680a213a"
/>
<ROLE
ROLE_ID = "1"
NAME = "ADMIN"
/>
<USER_ROLE
USER_ID = "1"
ROLE_ID = "1"
/>
</dataset>
实体
@Entity
@Table(name = "USER", schema="db_ca")
public class User {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="USER_ID", nullable=false)
private Long id;
...
}
@Entity
@Table(name = "ROLE", schema="db_ca" )
public class Role {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="ROLE_ID", nullable=false)
private Long id;
...
}
Class测试AccessServiceIT.java
@DataSet("/datasets/UsuarioServiceTest.xml")
@RunWith(UnitilsJUnit4TestClassRunner.class)
@SpringApplicationContext("testContext.xml")
public class AccessServiceIT {
@SpringBean("AccessServiceImpl")
private AccessService accessService;
@Test
public void accessTest() {
CredentialsBean credentialsBean = accessService.confirmLogon("test@test.com", "e8d95a51f3af4a3b134bf6bb680a213a");
assertEquals("test@test.com", credentialsBean.getLogon());
assertEquals(true, credentialsBean.isAuthenticated());
}
}
我找到了问题的解决方案。我只是将以下 属性 放在 unitils.properties 中,现在一切正常。
org.dbunit.database.IMetadataHandler.implClassName=org.dbunit.ext.mysql.MySqlMetadataHandler
我在这里找到了解决方案
希望对遇到同样错误的人有所帮助。
我没有使用 Unitils,而是直接调用了 dbunit。我通过设置连接的 属性 解决了这个问题:
final IDatabaseConnection connection = new DatabaseConnection(dataSource.getConnection());
connection.getConfig()
.setProperty(DatabaseConfig.PROPERTY_METADATA_HANDLER, new MySqlMetadataHandler());
对我来说,我得到这个错误,因为该列没有在休眠实体中声明,但该列存在于 table(oracle 数据库)中。这就是为什么 Dbunit 数据集 tought 列可能以小写或大写形式声明,但根本没有声明。异常消息不准确。
在我的例子中,这个错误发生在 XML 文件使用 @DatabaseSetup
模拟数据库的测试中。
我必须向 companyOffice
个实体添加一个新列,但是还有 company
个实体,并且都混在了 XML 文件中。因此,我将该列添加到 company
实体,但它最终试图在错误的位置找到该字段。
我不是很细心,但是错误信息一点也不清楚。
我的 java 应用程序将您的信息存储在 MySql 数据库版本 8 中。用户信息和密码存储在该数据库中。我正在实施一个集成测试来测试使用 dbunit 验证数据库中用户的方法。测试方法运行后出现如下错误
Caused by: org.dbunit.dataset.NoSuchColumnException: USER.USER_ID - (Non-uppercase input column: USER_ID) in ColumnNameToIndexes cache map. Note that the map's column names are NOT case sensitive.
我通过 MySql Workbench 检查 table 和列都是用大写字母创建的,因此显示的错误消息没有意义。有谁知道是什么导致了这个异常?
testContext.xml
unitils.properties
unitils.module.hibernate.enabled=true
unitils.module.jpa.enabled=false
unitils.module.easymock.enabled=false
database.url=jdbc:mysql://192.168.0.12:3306/db_ca?useUnicode=true&characterEncoding=UTF-8&serverTimezone=America/Sao_Paulo
database.driverClassName=com.mysql.jdbc.Driver
database.userName=root
database.password=9999
database.schemaNames=db_main, db_ca
database.dialect=mysql
unitils.module.database.className=com.myapplication.test.unitils.SingleConnectionDatabaseModule
DatabaseModule.Transactional.value.default=disabled
DbUnitModule.DataSet.loadStrategy.default=org.unitils.dbunit.datasetloadstrategy.impl.CleanInsertLoadStrategy
updateDataBaseSchema.enabled=true
dbMaintainer.script.locations=src/test/dbscripts
dbMaintainer.autoCreateExecutedScriptsTable=true
dbMaintainer.generateDataSetStructure.enabled=false
dbMaintainer.preserve.schemas=
在 src/test/dbscripts 中存在文件 001_SCRIPT_01.00.00
SET character_set_client = utf8mb4 ;
CREATE TABLE db_ca.ROLE (
ROLE_ID INT(11) NOT NULL AUTO_INCREMENT,
NAME VARCHAR(200) NOT NULL,
PRIMARY KEY (ROLE_ID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
SET character_set_client = utf8mb4 ;
CREATE TABLE db_ca.USER (
USER_ID INT(11) NOT NULL AUTO_INCREMENT,
EMAIL VARCHAR(100) NULL DEFAULT NULL,
NAME VARCHAR(150) NOT NULL,
PASSWORD VARCHAR(200) NOT NULL,
PRIMARY KEY (USER_ID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
SET character_set_client = utf8mb4 ;
CREATE TABLE db_ca.USER_ROLE (
ROLE_ID INT(11) NOT NULL,
USER_ID INT(11) NOT NULL,
PRIMARY KEY (ROLE_ID, USER_ID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
/datasets/UserServiceTest.xml
<?xml version="1.0" encoding="UTF-8"?>
<dataset xmlns="db_ca">
<USER
USER_ID = "1"
EMAIL = "test@test.com"
NAME = "TEST"
PASSWORD = "e8d95a51f3af4a3b134bf6bb680a213a"
/>
<ROLE
ROLE_ID = "1"
NAME = "ADMIN"
/>
<USER_ROLE
USER_ID = "1"
ROLE_ID = "1"
/>
</dataset>
实体
@Entity
@Table(name = "USER", schema="db_ca")
public class User {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="USER_ID", nullable=false)
private Long id;
...
}
@Entity
@Table(name = "ROLE", schema="db_ca" )
public class Role {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="ROLE_ID", nullable=false)
private Long id;
...
}
Class测试AccessServiceIT.java
@DataSet("/datasets/UsuarioServiceTest.xml")
@RunWith(UnitilsJUnit4TestClassRunner.class)
@SpringApplicationContext("testContext.xml")
public class AccessServiceIT {
@SpringBean("AccessServiceImpl")
private AccessService accessService;
@Test
public void accessTest() {
CredentialsBean credentialsBean = accessService.confirmLogon("test@test.com", "e8d95a51f3af4a3b134bf6bb680a213a");
assertEquals("test@test.com", credentialsBean.getLogon());
assertEquals(true, credentialsBean.isAuthenticated());
}
}
我找到了问题的解决方案。我只是将以下 属性 放在 unitils.properties 中,现在一切正常。
org.dbunit.database.IMetadataHandler.implClassName=org.dbunit.ext.mysql.MySqlMetadataHandler
我在这里找到了解决方案
希望对遇到同样错误的人有所帮助。
我没有使用 Unitils,而是直接调用了 dbunit。我通过设置连接的 属性 解决了这个问题:
final IDatabaseConnection connection = new DatabaseConnection(dataSource.getConnection());
connection.getConfig()
.setProperty(DatabaseConfig.PROPERTY_METADATA_HANDLER, new MySqlMetadataHandler());
对我来说,我得到这个错误,因为该列没有在休眠实体中声明,但该列存在于 table(oracle 数据库)中。这就是为什么 Dbunit 数据集 tought 列可能以小写或大写形式声明,但根本没有声明。异常消息不准确。
在我的例子中,这个错误发生在 XML 文件使用 @DatabaseSetup
模拟数据库的测试中。
我必须向 companyOffice
个实体添加一个新列,但是还有 company
个实体,并且都混在了 XML 文件中。因此,我将该列添加到 company
实体,但它最终试图在错误的位置找到该字段。
我不是很细心,但是错误信息一点也不清楚。