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

MyBatis之insert主鍵自增和自定義主鍵詳解

 更新時(shí)間:2024年12月25日 15:12:15   作者:千葉重樓  
本文介紹了如何使用MyBatis解決插入數(shù)據(jù)時(shí)因主鍵唯一性約束導(dǎo)致的錯(cuò)誤問題,以及如何自定義主鍵生成規(guī)則,文中詳細(xì)解釋了如何在MyBatis中配置自增主鍵,并提供了測(cè)試示例

一、實(shí)現(xiàn)描述

我們?cè)趯懗绦驎r(shí),時(shí)常會(huì)遇到這樣的問題:

插入一條數(shù)據(jù),但因有主鍵的存在,而有時(shí)候會(huì)報(bào)“違反唯一性約束”的錯(cuò)誤,

下面呢,我們就來(lái)利用MyBatis來(lái)解決這個(gè)問題。

二、此文使用的數(shù)據(jù)庫(kù)為MySQL

如需要使用其他數(shù)據(jù)庫(kù),請(qǐng)做適當(dāng)更改即可。

三、根據(jù)主鍵的自增

在MyBatis中進(jìn)行配置實(shí)現(xiàn),實(shí)現(xiàn)如下:

<insert id="insertRole" parameterType="role" useGeneratedKeys="true" keyProperty="id">
   insert into t_role(role_name,note) values (#{roleName},#{note})
</insert>

解析:

1、我們使用keyProperty屬性指定id為主鍵字段,同時(shí)使用useGeneratedKeys屬性告訴MyBatis這個(gè)主鍵是否使用數(shù)據(jù)庫(kù)的內(nèi)置規(guī)則生成。

2、其中,在數(shù)據(jù)庫(kù)中設(shè)置id的自增規(guī)則,如下所示:

mysql>alter table t_role change id id int primary key auto_increment;

3、在上面配置中,我們指定了id列為自增字段,因此我們建立POJO,這樣的話,使用MyBatis的主鍵回填功能,實(shí)現(xiàn)正確的插入操作(無(wú)需設(shè)置id的值,MyBatis會(huì)用數(shù)據(jù)庫(kù)的設(shè)置進(jìn)行處理)。

4、測(cè)試:

sqlSession = SqlSessionFactoryUtil.openSqlSession();
RoleMapper roleMapper = sqlSession.getMapper(RoleMapper.class);
Role role = new Role();
role.setRoleName("test4");
role.setNote("test4Note");
roleMapper.insertRole(role);
System.err.println(role.getId());

四、自定義主鍵生成規(guī)則實(shí)現(xiàn)

實(shí)例如下:

<insert id="insertRole" parameterType="role" useGeneratedKeys="true" keyProperty="id">
    <selectKey keyProperty="id" resultTyle="int" order="BEFORE">
             select if(max(id) is null, 1, max(id) + 2) as newId from t_role
     </selectKey>
     insert into t_role(id,role_name,note) values(#{id},#{roleName},#{note});
</insert>

解析:

上面顯示的為MyBatis定義自增規(guī)則的配置,其實(shí)上面的selectKey配置類似于數(shù)據(jù)庫(kù)中的觸發(fā)器,order=“BEFORE”規(guī)定了在執(zhí)行語(yǔ)句之前執(zhí)行newId的查找,然后在執(zhí)行插入語(yǔ)句。

這樣我們就利用自定義的主鍵規(guī)則實(shí)現(xiàn)了數(shù)據(jù)的新增。

總結(jié)

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

相關(guān)文章

  • Spring Boot使用模板freemarker的示例代碼

    Spring Boot使用模板freemarker的示例代碼

    本篇文章主要介紹了Spring Boot使用模板freemarker的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-10-10
  • Java實(shí)現(xiàn)屏幕截圖工具的代碼分享

    Java實(shí)現(xiàn)屏幕截圖工具的代碼分享

    這篇文章主要為大家介紹了如何利用Java語(yǔ)言編寫一個(gè)電腦屏幕截圖工具,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)有一定的幫助,需要的可以參考一下
    2022-05-05
  • Java中的SimpleDateFormat的線程安全問題詳解

    Java中的SimpleDateFormat的線程安全問題詳解

    這篇文章主要介紹了Java中的SimpleDateFormat的線程安全問題詳解,sonar 是一個(gè)代碼質(zhì)量管理工具,SonarQube是一個(gè)用于代碼質(zhì)量管理的開放平臺(tái),為項(xiàng)目提供可視化報(bào)告, 連續(xù)追蹤項(xiàng)目質(zhì)量演化過程,需要的朋友可以參考下
    2024-01-01
  • Java拼接字符串時(shí)如何去掉最后一個(gè)多余的逗號(hào)

    Java拼接字符串時(shí)如何去掉最后一個(gè)多余的逗號(hào)

    當(dāng)我們遍歷拼接字符串的時(shí)候,最后會(huì)多出一個(gè)我們添加的字符(比如逗號(hào)),下面通過實(shí)例代碼給大家介紹Java拼接字符串時(shí)去掉最后一個(gè)多余的逗號(hào),感興趣的朋友跟隨小編一起看看吧
    2024-12-12
  • 詳解Java利用ExecutorService實(shí)現(xiàn)同步執(zhí)行大量線程

    詳解Java利用ExecutorService實(shí)現(xiàn)同步執(zhí)行大量線程

    這篇文章主要介紹了Java利用ExecutorService實(shí)現(xiàn)同步執(zhí)行大量線程,ExecutorService可以維護(hù)我們的大量線程在操作臨界資源時(shí)的穩(wěn)定性。
    2017-03-03
  • 被遺忘的Java關(guān)鍵字transient的使用詳解

    被遺忘的Java關(guān)鍵字transient的使用詳解

    在 Java 中,transient 是一個(gè)關(guān)鍵字,用于指定一個(gè)類的字段(成員變量)在序列化時(shí)應(yīng)該被忽略。本文將通過示例為大家簡(jiǎn)單講講transient的使用,需要的可以參考一下
    2023-04-04
  • Java字符串原理分析之String是否可變

    Java字符串原理分析之String是否可變

    當(dāng)我們?cè)谇舐殨r(shí),面試官很喜歡問我們關(guān)于String的一些原理性知識(shí),比如String的不可變性、字符串的內(nèi)存分配等,為了讓大家更好地應(yīng)對(duì)面試,并理解String的底層設(shè)計(jì),接下來(lái)會(huì)給大家聊聊String的一些原理,比如String為什么具有不可變性,需要的朋友可以參考下
    2023-05-05
  • Java執(zhí)行JavaScript代碼

    Java執(zhí)行JavaScript代碼

    這篇文章主要為大家詳細(xì)介紹了Java執(zhí)行JavaScript代碼的具體操作方法,感興趣的小伙伴們可以參考一下
    2016-03-03
  • Spring Data Redis對(duì)象緩存序列化問題解決

    Spring Data Redis對(duì)象緩存序列化問題解決

    相信在項(xiàng)目中,你一定是經(jīng)常使用Redis,在使用時(shí),有沒有遇到同我一樣,對(duì)象緩存序列化問題的呢,本文主要介紹了Spring Data Redis對(duì)象緩存序列化問題解決,感興趣的可以了解一下
    2024-01-01
  • SpringBoot在項(xiàng)目中訪問靜態(tài)資源步驟分析

    SpringBoot在項(xiàng)目中訪問靜態(tài)資源步驟分析

    今天在玩SpringBoot的demo的時(shí)候,放了張圖片在resources目錄下,啟動(dòng)區(qū)訪問的時(shí)候,突然好奇是識(shí)別哪些文件夾來(lái)展示靜態(tài)資源的, 為什么有時(shí)候放的文件夾不能顯示,有的卻可以
    2023-01-01

最新評(píng)論