我将 MyBatis 与 Oracle 11g R2 数据库结合使用。我正在使用 MyBatis 3.3 和 ojdbc6 12.1.0.2。我的问题是每当我尝试插入一个空对象时我都会得到以下信息。
org.springframework.jdbc.UncategorizedSQLException:错误设置为空
对于参数 #8 和 JdbcType OTHER 。尝试设置不同的
此参数的 JdbcType 或不同的 jdbcTypeForNull
配置属性。原因:java.sql.SQLException:无效列
类型:1111
我的理解是,在最新版本的 JDBC 中,null 映射到 JdbcType.OTHERS,并非所有驱动程序都能处理,显然 Oracle 就是其中之一。
我在 MyBatis 配置中尝试了以下操作,但仍然没有成功。
@Bean
public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
sessionFactory.setTypeAliasesPackage("org.ohtech.innovationexchange.core.domain");
sessionFactory.setTransactionFactory(springManagedTransactionFactory());
sessionFactory.setConfigurationProperties(getProperties());
return sessionFactory.getObject();
}
@Bean(name = "transactionManager")
public DataSourceTransactionManager dataSourceTransactionManager() throws PropertyVetoException{
return new DataSourceTransactionManager(dataSource());
}
@Bean
public SpringManagedTransactionFactory springManagedTransactionFactory() {
return new SpringManagedTransactionFactory();
}
private Properties getProperties() {
final Properties myBatisProperties = new Properties();
myBatisProperties.put("jdbcTypeForNull", "NULL");
return myBatisProperties;
}
我可以通过在我的映射器文件中执行以下操作来使其工作,但它看起来确实重复且丑陋。不知道为什么 MyBatis 不使用我的属性,我正在传递 SqlSessionFactory bean。
“jdbcTypeForNull”不是“属性”而是“设置”。我猜目前无法通过java配置进行设置。你需要一个像这样的config.xml:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<settings>
<setting name="jdbcTypeForNull" value="NULL" />
</settings>
</configuration>
并使用 sessionFactory.setConfigLocation(...)。
设置和属性的区别请参考文档:https://mybatis.github.io/mybatis-3/configuration.html https://mybatis.github.io/mybatis-3/configuration.html
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)