欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis使用useGeneratedKeys獲取自增主鍵

 更新時間:2023年01月12日 10:22:57   作者:Applehope  
這篇文章主要為大家介紹了Mybatis使用useGeneratedKeys獲取自增主鍵示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

一、useGeneratedKeys 是什么 ?

關于useGeneratedKeys,官方的說法是,這個參數(shù)的作用是:"允許 JDBC 支持自動生成主鍵,需要驅(qū)動兼容",如何理解這句話的含義?

其原意是。對于支持自動生成記錄主鍵的數(shù)據(jù)庫,如 MySQL 和 SQL Server,此時將 useGeneratedKeys 參數(shù)的值設置為 true,則進行 INSERT 操作后,數(shù)據(jù)庫自動生成的主鍵會填充到 Java 實體屬性中,我們可以從 Java 實體屬性中獲得數(shù)據(jù)庫自動生成的主鍵 ID。

二、如何使用?

配置useGeneratedKeys,可以通過以下方式實現(xiàn):

  • 配置全局配置文件
  • 在 xml 映射器中配置 useGeneratedKeys 參數(shù)
  • 在接口映射器中設置 useGeneratedKeys 參數(shù)

2.1 在 mybatis 的全局配置文件中配置

application.yml 配置文件

通過 configLocation 指定 mybatis 的配置文件 mybatis-config.xml

# MyBatis configuration
mybatis:
    # Search for the specified package alias
    typeAliasesPackage: com.ruoyi.**.domain
    # Configure mapper scan to find all mapper.xml mapping files
    mapperLocations: classpath*:mapper/**/*Mapper.xml
    # Load the global configuration file
    configLocation: classpath:mybatis/mybatis-config.xml

mybatis-config.xml

通過<setting name="useGeneratedKeys" value="true" />激活useGeneratedKeys.

<?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="cacheEnabled" value="true" /> <!-- global mapper enables caching -->
                <setting name="useGeneratedKeys" value="true" /> <!-- Allow JDBC to support automatic generation of primary keys -->
                <setting name="defaultExecutorType" value="REUSE" /> <!-- configure the default executor -->
                <setting name="logImpl" value="SLF4J" /> <!-- Specify the specific implementation of the log used by MyBatis -->
<!-- <setting name="mapUnderscoreToCamelCase" value="true"/> <!– CamelCase naming–>-->
        </settings>
</configuration>

注意:在settings元素中設置的全局 useGeneratedKeys 參數(shù)對 xml 后綴的 mapper 無效。如果你想在 xml 后綴的 mapper 中添加記錄后返回主鍵 ID,你必須在 xml 后綴的 mapper 中明確設置useGeneratedKeys參數(shù)的值為 true。

2.2 在 xml mapper 中配置 useGeneratedKeys 參數(shù)。

Mapper.xml

<insert id="addBigdataGroup" parameterType="BigdataGroup" useGeneratedKeys="true" keyProperty="groupId" keyColumn="group_id">
        insert into bigdata_group (
        group_id, group_name, comment, business_line, create_by, remark, create_time)
        values(#{groupId}, #{groupName}, #{comment}, #{businessLine}, #{createBy}, #{remark}, sysdate() );
</insert>

parameterType  傳入?yún)?shù)類型

keyProperty JAVA 對象中的屬性名稱

keyColumn  數(shù)據(jù)庫字段名稱

keyProperty與keyColumn的關系圖示(來自網(wǎng)絡).png

再次說明:在 xml mapper 中配置的 useGeneratedKeys 參數(shù)只影響 xml mapper,設置元素中設置的全局 useGeneratedKeys 參數(shù)值對 xml mapper 沒有影響。

2.3 在 interface mapper 中設置 useGeneratedKeys 參數(shù)

設置 useGeneratedKeys 為 true,返回由數(shù)據(jù)庫自動生成的記錄主鍵 id。

@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
@Insert("insert into test(name,descr,url,create_time,update_time) values(#{name},#{descr},#{url},now(),now())")
Integer insertOneTest(Test test);

注意:在 interface mapper 中設置的 useGeneratedKeys參數(shù)將覆蓋 mybatis 配置文件中 setting 元素內(nèi)所配置的useGeneratedKeys的值。

另外筆者的實踐中,keyProperty = "id"并未生效,需要設置為keyProperty = "test.id";即參數(shù)的名稱 + . + 主鍵屬性名。 讀者老師需結(jié)合自己的環(huán)境試一試。

三、遇到的問題

在配置了獲得主鍵 ID 后,但返回的結(jié)果并沒有像預期的那樣返回新插入數(shù)據(jù)庫行的主鍵的真實數(shù)據(jù)。但返回的居然1。

代碼示例如下:

  • Mybatis 側(cè)
import java.util.List;
public interface BigdataMapper {
    List&lt;BigdataGroup&gt; getBigdataGroup();
    int addBigdataGroup(BigdataGroup bigdataGroup);
}
  • service 側(cè)
public int addBigdataGroup(BigdataGroup bigdataGroup) {
    bigdataGroup.setCreateBy(SecurityUtils.getUsername());
    int update = bigdataMapper. addBigdataGroup(bigdataGroup);
    log.info("update: {}", update);
    return update;
}
  • xml file側(cè)
<insert id="addBigdataGroup" parameterType="BigdataGroup" useGeneratedKeys="true" keyProperty="groupId" keyColumn="group_id">
    insert into bigdata_group (
    group_id, group_name, comment, business_line, create_by, remark, create_time)
    values(#{groupId}, #{groupName}, #{comment}, #{businessLine}, #{createBy}, #{remark}, sysdate() );
</insert>
  • 打印結(jié)果

按理說,返回的結(jié)果應該是插入后主鍵中的真實數(shù)據(jù),但返回結(jié)果是1

注意:真實的 id 已經(jīng)被注入到參數(shù)傳遞對象的主鍵的相應屬性中,方法的返回值實際表示的是插入的行數(shù),因為插入了 1 條記錄,所以返回值是 1;如果要獲得新添加數(shù)據(jù)的自增ID,那么只需要讀取對象中對應的自增ID屬性的值。

修改獲取主鍵值的方式:

public int addBigdataGroup(BigdataGroup bigdataGroup) {
    bigdataGroup.setCreateBy(SecurityUtils.getUsername());
    int update = bigdataMapper. addBigdataGroup(bigdataGroup);
    log.info("update: {}", update);
    // Add the following code
    int group_id = bigdataGroup. getGroupId();
    log.info("group_id: {}", group_id);
    // stop here
    return update;
}

結(jié)語

英文原文:zditect.com/code/mybati…

以上就是Mybatis使用useGeneratedKeys獲取自增主鍵的詳細內(nèi)容,更多關于Mybatis useGeneratedKeys自增主鍵的資料請關注腳本之家其它相關文章!

相關文章

  • 深入學習JAVA GC日志的相關知識

    深入學習JAVA GC日志的相關知識

    JVM 在Java應用程序優(yōu)化中是不可缺少的一大重項,如何合理配置Java參數(shù),如何驗證配置參數(shù)的有效性,從GC日志中可以獲得很重要的提示。下面小編就帶大家來一起學習一下吧
    2019-06-06
  • Java并發(fā)編程如何降低鎖粒度并實現(xiàn)性能優(yōu)化

    Java并發(fā)編程如何降低鎖粒度并實現(xiàn)性能優(yōu)化

    這篇文章主要介紹了Java并發(fā)編程如何降低鎖粒度并實現(xiàn)性能優(yōu)化,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-08-08
  • 關于通過Java連接mysql對反斜杠”\“轉(zhuǎn)義的測試詳解

    關于通過Java連接mysql對反斜杠”\“轉(zhuǎn)義的測試詳解

    這篇文章主要給大家介紹了關于通過Java連接mysql對反斜杠”\“轉(zhuǎn)義的測試的相關資料,文中通過實例代碼介紹的非常詳細,對大家理解反斜杠”\“轉(zhuǎn)義具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-06-06
  • springboot自動裝配的源碼與流程圖

    springboot自動裝配的源碼與流程圖

    在日常的開發(fā)過程中Spring Boot自動裝配的特性給我們開發(fā)減少了很多重復性的工作,這篇文章主要給大家介紹了關于springboot自動裝配的相關資料,需要的朋友可以參考下
    2021-08-08
  • java中的按位與(&)用法說明

    java中的按位與(&)用法說明

    這篇文章主要介紹了java中的按位與(&)用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • elasticsearch構造Client實現(xiàn)java客戶端調(diào)用接口示例分析

    elasticsearch構造Client實現(xiàn)java客戶端調(diào)用接口示例分析

    這篇文章主要為大家介紹了elasticsearch構造Client實現(xiàn)java客戶端調(diào)用接口示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-04-04
  • Java如何從json字符串中獲取某個值詳解

    Java如何從json字符串中獲取某個值詳解

    Java開發(fā)當中經(jīng)常需要Json格式的數(shù)據(jù),下面這篇文章主要給大家介紹了關于Java如何從json字符串中獲取某個值的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • LibrarySystem圖書管理系統(tǒng)開發(fā)(一)

    LibrarySystem圖書管理系統(tǒng)開發(fā)(一)

    這篇文章主要為大家詳細介紹了LibrarySystem圖書管理系統(tǒng)開發(fā),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Java使用PDFBox實現(xiàn)操作PDF文檔

    Java使用PDFBox實現(xiàn)操作PDF文檔

    這篇文章主要為大家詳細介紹了Java如何使用PDFBox實現(xiàn)操作PDF文檔,例如添加本地圖片、添加網(wǎng)絡圖片、圖片寬高自適應、圖片水平垂直居中對齊等功能,需要的可以了解下
    2024-03-03
  • Java運用SWT插件編寫桌面記事本應用程序

    Java運用SWT插件編寫桌面記事本應用程序

    這篇文章主要為大家介紹了一個Java項目實戰(zhàn),一步步教你實現(xiàn)記事本,步驟很詳細,運用SWT插件手把手編寫記事本,感興趣的小伙伴們可以參考一下
    2016-01-01

最新評論