亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MyBatis注解開發(fā)-@Insert和@InsertProvider的使用

 更新時(shí)間:2022年07月04日 10:29:53   作者:哈夫熱曼  
這篇文章主要介紹了MyBatis注解開發(fā)-@Insert和@InsertProvider的使用,具有很好的參考價(jià)值,希望對大家有所幫助。

@Insert和@InsertProvider的使用

首先,在mybatis-generator.xml中配置返回主鍵

UserMapper中的

  • @SelectKey:返回主鍵,具體解釋見下面說明
  • @InsertProvider:type指明SQL工廠類,method是工廠類里對應(yīng)的方法

@SelectKey注解源碼

  • statement是要運(yùn)行的SQL語句,它的返回值通過resultType來指定before表示查詢語句statement運(yùn)行的時(shí)機(jī)
  • keyProperty表示查詢結(jié)果賦值給代碼中的哪個(gè)對象,keyColumn表示將查詢結(jié)果賦值給數(shù)據(jù)庫表中哪一列
  • keyProperty和keyColumn都不是必需的,有沒有都可以
  • before=true,插入之前進(jìn)行查詢,可以將查詢結(jié)果賦給keyProperty和-keyColumn,賦給keyColumn相當(dāng)于更改數(shù)據(jù)庫
  • befaore=false,先插入,再查詢,這時(shí)只能將結(jié)果賦給keyProperty
  • 賦值給keyProperty用來“讀”數(shù)據(jù)庫,賦值給keyColumn用來寫數(shù)據(jù)庫

selectKey的兩大作用:

  • 1、生成主鍵;
  • 2、獲取剛剛插入數(shù)據(jù)的主鍵。

注意:在MYSQL 中 , order是AFTER , 因?yàn)楫?dāng)前及記錄的主鍵值在insert語句執(zhí)行成功之后才能拿到 , 而在ORACLE中 ,oder是BEFORE , 因?yàn)镺RACLE需要先從序列取到值 , 再將其作為主鍵插入到數(shù)據(jù)庫

另外,附上UserMapper.xml形式的返回主鍵方法

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--
實(shí)體類的映射文件
namespace 指定接口的類全名
-->
<mapper namespace="com.wzl.dao.UserMapper">
       <!--
            方案一: 這表的主鍵必須是自增長的 auto_increment
                 useGeneratedKeys="true" 讓自增長的主鍵開啟返回功能
                 keyColumn="id"  user表中主鍵列
                 keyProperty="id" user實(shí)體主鍵屬性
                 注意:支持主鍵自增類型的數(shù)據(jù)庫 MySQL 和 SqlServer , oracle不支持
       -->
    <insert id="addUser" useGeneratedKeys="true" keyColumn="id" keyProperty="id">
         insert into user values(null,#{user.username},#{user.birthday},#{user.sex},#{user.address})
    </insert>
    <!--
            方案二: <selectKey>
             keyColumn="id" user表中主鍵列
             keyProperty="id" user實(shí)體主鍵屬性
             resultType="int" user實(shí)體主鍵屬性類型
             order="AFTER"  表示此標(biāo)簽內(nèi)部sql語句在insert執(zhí)行之前(執(zhí)行),還是之后執(zhí)行(執(zhí)行)
                AFTER 之后執(zhí)行【在自增主鍵時(shí)】
                BEFORE 之前執(zhí)行【使用指定主鍵時(shí)】
在MYSQL 中 , order是AFTER , 因?yàn)楫?dāng)前及記錄的主鍵值在insert語句執(zhí)行成功之后才能拿到 , 而在ORACLE中 ,oder是BEFORE , 因?yàn)镺RACLE需要先從序列取到值 , 再將其作為主鍵插入到數(shù)據(jù)庫
    -->
    <insert id="addUser2">
        <selectKey keyColumn="id" keyProperty="id" resultType="int" order="AFTER">
            SELECT LAST_INSERT_ID()
        </selectKey>
        insert into user values(null, #{username},#{birthday},#{sex},#{address})
    </insert>
</mapper>

使用InsertProvider注解報(bào)錯解決過程

目前項(xiàng)目在使用mybatis,并且是使用注解的方式。

在使用InsertProvider注解的時(shí)候報(bào)了一下的錯誤:

org.apache.ibatis.builder.BuilderException: Could not find value method on SQL annotation.  Cause: org.apache.ibatis.builder.BuilderException: Error creating SqlSource for SqlProvider. Method........

注解是如下這個(gè)樣子的

@InsertProvider(method = "insertlist",type=SqlProvider.class)
?public int insertInnerTable(List list,String dbTable);

思路是要寫一個(gè)通用的插入一個(gè)集合的方法,但是在執(zhí)行的時(shí)候就報(bào)了上面的錯誤。在網(wǎng)上查資料未果。

于是只能自己動手,豐衣足食了。

一步步跟斷點(diǎn),跟到mybatis了報(bào)錯的方法中,發(fā)現(xiàn)了如下的代碼

try {
? ? ? this.sqlSourceParser = new SqlSourceBuilder(config);
? ? ? this.providerType = (Class<?>) provider.getClass().getMethod("type").invoke(provider);
? ? ? providerMethodName = (String) provider.getClass().getMethod("method").invoke(provider);
? ? ? for (Method m : this.providerType.getMethods()) {
? ? ? ? if (providerMethodName.equals(m.getName())) {
? ? ? ? ? if (m.getParameterTypes().length < 2
? ? ? ? ? ? ? && m.getReturnType() == String.class) {
? ? ? ? ? ? this.providerMethod = m;
? ? ? ? ? ? this.providerTakesParameterObject = m.getParameterTypes().length == 1;
? ? ? ? ? }
? ? ? ? }
? ? ? }
? ? } catch (Exception e) {
? ? ? throw new BuilderException("Error creating SqlSource for SqlProvider. ?Cause: " + e, e);
? ? }

注意標(biāo)黃的位置,終于發(fā)現(xiàn)導(dǎo)致錯誤的罪魁禍?zhǔn)琢?,原來是這里限制了參數(shù)的個(gè)數(shù),不能操作兩個(gè)參數(shù)的啊。

于是將方法以及注解改為如下形式

@InsertProvider(method = "insert",type=SqlProvider.class)
?public int insert(SqlContext sqlContext);

在SqlProvider中對應(yīng)的方法為

public String insert(SqlContext sqlContext){
? ? ? ........
}

至此問題解決!

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • java實(shí)現(xiàn)簡單的計(jì)算器類實(shí)例

    java實(shí)現(xiàn)簡單的計(jì)算器類實(shí)例

    這篇文章主要介紹了java實(shí)現(xiàn)簡單的計(jì)算器類,涉及java針對鍵盤監(jiān)聽及數(shù)字運(yùn)算的處理技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-10-10
  • Spring加載XSD文件發(fā)生錯誤的解決方法

    Spring加載XSD文件發(fā)生錯誤的解決方法

    這篇文章主要介紹了Spring加載XSD文件發(fā)生錯誤的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • mybatis實(shí)體類字段大小寫及字段獲取不到值問題

    mybatis實(shí)體類字段大小寫及字段獲取不到值問題

    這篇文章主要介紹了mybatis實(shí)體類字段大小寫及字段獲取不到值問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • MyBatis映射文件resultMap元素中使用多個(gè)association的方法

    MyBatis映射文件resultMap元素中使用多個(gè)association的方法

    這篇文章主要介紹了MyBatis映射文件resultMap元素中使用多個(gè)association的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Spring Boot的應(yīng)用啟動與關(guān)閉的方法

    Spring Boot的應(yīng)用啟動與關(guān)閉的方法

    本篇文章主要介紹了Spring Boot的應(yīng)用啟動與關(guān)閉的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-12-12
  • Java substring原理及使用方法實(shí)例

    Java substring原理及使用方法實(shí)例

    這篇文章主要介紹了Java substring原理及使用方法實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Spring純Java配置集成kafka代碼實(shí)例

    Spring純Java配置集成kafka代碼實(shí)例

    這篇文章主要介紹了Spring純Java配置集成kafka代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • Mybatis一對多查詢的兩種姿勢(值得收藏)

    Mybatis一對多查詢的兩種姿勢(值得收藏)

    這篇文章主要給大家介紹了關(guān)于Mybatis一對多查詢的兩種姿勢,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • java編程實(shí)現(xiàn)簡單的網(wǎng)絡(luò)爬蟲示例過程

    java編程實(shí)現(xiàn)簡單的網(wǎng)絡(luò)爬蟲示例過程

    這篇文章主要為大家介紹了如何使用java編程實(shí)現(xiàn)一個(gè)簡單的網(wǎng)絡(luò)爬蟲示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-10-10
  • Java8新特性之Stream使用詳解

    Java8新特性之Stream使用詳解

    這篇文章主要介紹了Java8新特性之Stream使用詳解,流是用來處理集合中的數(shù)據(jù),以聲明的形式操作集合,它就像SQL語句,我們只需告訴流需要對集合進(jìn)行什么操作,它就會自動進(jìn)行操作,并將執(zhí)行結(jié)果交給你,無需我們自己手寫代碼,需要的朋友可以參考下
    2023-08-08

最新評論