使用【mybatis + oracle】時報錯:java.sql.SQLException 無效的列類型

緣由--MyBatis中源碼分析

參考網頁

http://makemyownlife.iteye.com/blog/1610021html

詳細見網頁,摘抄幾段

MyBatis 插入空值時,須要指定JdbcTypespring

mybatis insert空值報空值異常,可是在pl/sql不會提示錯誤,主要緣由是mybatis沒法進行轉換sql

 

由於你傳入的參數的字段爲null對象沒法獲取對應的jdbcType類型,而報的錯誤。數據庫

你只要在insert語句中insert的對象加上jdbcType就能夠了,修改以下:緩存

#{menuTitle,jdbcType=VARCHAR}mybatis

這樣就能夠解決以上錯誤了。oracle

 

在向oracle插入數據時,mybatis3報Error setting null parameter. Most JDBC drivers require that the JdbcType must be specified for all nullable parameters,是因爲參數出現了null值,對於Mybatis,若是進行操做的時候,沒有指定jdbcType類型的參數,mybatis默認jdbcType.OTHER致使,給參數加上jdbcType可解決(注意大小寫)app

解決方法

方法1--將空值字段賦值

https://blog.csdn.net/hellostory/article/details/6117183源碼分析

方法2--MyBatis 插入空值時,須要指定JdbcType

http://www.javashuo.com/article/p-cmrccszg-cz.htmlui

示例

public interface MyAttachmentDao {
    @Insert("insert into attachments(objId,name,fileType,updateTimestamp,superName) values(#{objId,jdbcType=INT},#{name,jdbcType=VARCHAR},#{fileType,jdbcType=CHAR},#{updateTimestamp,jdbcType=TIMESTAMP},#{superName,jdbcType=VARCHAR})")
    @Options(useGeneratedKeys=true,keyProperty="id")
    int insert(MyAttachmentBean a);
}

經常使用的jdbcType

jdbcType=INT

jdbcType=VARCHAR

jdbcType=CHAR

dbcType=TIMESTAMP

方法3

https://my.oschina.net/dailongyao/blog/495070

開始sql是這樣寫的insert into user(id,name) values(#{id},#{name}) 

解決方法:

1、指定插入值得jdbcType,將sql改爲 insert into user(id,name) values(#{id,jdbcType=VARCHAR},#{name,jdbcType=VARCHAR}) 

 

2、在mybatis-config.xml文件中配置一下,添加settings配置,以下:(推薦)

<configuration>

......

<settings>

    <setting name="jdbcTypeForNull" value="NULL" />

</settings>

......

</configuration>

問題解決

注意--MyBatis中標籤順序必須寫正確

MyBatis配置文件報錯【The content of element type "configuration" must match】

參考網頁

https://blog.csdn.net/qq_35572020/article/details/60321823

正文

感謝原做者http://www.cnblogs.com/zhoumingming/p/5417014.html

注意每一個標籤必須按照順序寫,否則就會提示錯誤

順序是

<?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>

 

<!-- 加載屬性文件 -->
<properties resource="db.properties">
<!--properties中還能夠配置一些屬性名和屬性值 -->
<!-- <property name="jdbc.driver" value=""/> -->
</properties>


<!-- 全局配置參數,須要時再設置 -->

<settings>
<!-- 打開延遲加載 的開關 -->
<setting name="lazyLoadingEnabled" value="true"/>
<!-- 將積極加載改成消極加載即按須要加載 -->
<setting name="aggressiveLazyLoading" value="false"/>
<!-- 開啓二級緩存 -->
<setting name="cacheEnabled" value="true"/>
</settings>

<!-- 別名定義 -->
<typeAliases>

<!-- 針對單個別名定義
type:類型的路徑
alias:別名
-->
<!-- <typeAlias type="cn.itcast.mybatis.po.User" alias="user"/> -->
<!-- 批量別名定義 
指定包名,mybatis自動掃描包中的po類,自動定義別名,別名就是類名(首字母大寫或小寫均可以)
-->
<package name="cn.itcast.mybatis.po"/>

</typeAliases>

<!-- 和spring整合後 environments配置將廢除-->
<environments default="development">
<environment id="development">
<!-- 使用jdbc事務管理,事務控制由mybatis-->
<transactionManager type="JDBC" />
<!-- 數據庫鏈接池,由mybatis管理-->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</dataSource>
</environment>
</environments>
<!-- 加載 映射文件 -->
<mappers>
<mapper resource="sqlmap/User.xml"/>

<!--經過resource方法一次加載一個映射文件 -->
<!-- <mapper resource="mapper/UserMapper.xml"/> -->

<!-- 經過mapper接口加載單個 映射文件
遵循一些規範:須要將mapper接口類名和mapper.xml映射文件名稱保持一致,且在一個目錄 中
上邊規範的前提是:使用的是mapper代理方法
-->
<!-- <mapper class="cn.itcast.mybatis.mapper.UserMapper"/> -->

<!-- 批量加載mapper
指定mapper接口的包名,mybatis自動掃描包下邊全部mapper接口進行加載
遵循一些規範:須要將mapper接口類名和mapper.xml映射文件名稱保持一致,且在一個目錄 中
上邊規範的前提是:使用的是mapper代理方法
-->
<package name="cn.itcast.mybatis.mapper"/>

</mappers>

</configuration>

 

大致就是這個順序

個人錯誤--將 settings 標籤寫在了 typeAliases 標籤的前面

相關文章
相關標籤/搜索