MyBatis-Plus如何解決主鍵自增問(wèn)題
MyBatis-Plus主鍵自增失敗
1、先看錯(cuò)誤
Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@5c731754]
2022-12-05 21:05:55.322 ERROR 17476 --- [nio-8989-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet] : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.dao.DataIntegrityViolationException:
### Error updating database. Cause: com.mysql.cj.jdbc.exceptions.MysqlDataTruncation: Data truncation: Out of range value for column 'id' at row 1
### The error may exist in com/baidu/mapper/SysAccountMapper.java (best guess)
### The error may involve com.baidu.mapper.SysAccountMapper.insert-Inline
### The error occurred while setting parameters
### SQL: INSERT INTO account ( id, datatime ) VALUES ( ?, ? )
### Cause: com.mysql.cj.jdbc.exceptions.MysqlDataTruncation: Data truncation: Out of range value for column 'id' at row 1
; Data truncation: Out of range value for column 'id' at row 1; nested exception is com.mysql.cj.jdbc.exceptions.MysqlDataTruncation: Data truncation: Out of range value for column 'id' at row 1] with root causecom.mysql.cj.jdbc.exceptions.MysqlDataTruncation: Data truncation: Out of range value for column 'id' at row 1
大概意思就是說(shuō),mybatis-plus添加數(shù)據(jù)的主鍵失敗。
2、需求
想要數(shù)據(jù)庫(kù)中添加數(shù)據(jù),成自增的。
我明明在數(shù)據(jù)庫(kù)設(shè)置了主鍵id自增,但是添加數(shù)據(jù)的時(shí)候沒(méi)有自增那。
3、解決
1、在數(shù)據(jù)庫(kù)中添加確保是自增。
2、在實(shí)體類(lèi)上頁(yè)添加自增
4、自增策略
- 要想主鍵自增需要配置如下主鍵策略
- 需要在創(chuàng)建數(shù)據(jù)表的時(shí)候設(shè)置主鍵自增
- 實(shí)體字段中配置 @TableId(type = IdType.AUTO)
MyBatis-Plus插入后獲取自增主鍵
1、在主鍵上的**@TableId注解增加屬性 type**。
2、設(shè)置之后,在調(diào)用mapper.insert(domain)方法之后,插入完成后,直接能從domain中取到最新的主鍵。
結(jié)果如下:
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- MybatisPlus使用@TableId主鍵id自增長(zhǎng)無(wú)效的解決
- Mybatis使用useGeneratedKeys獲取自增主鍵
- 如何用注解的方式實(shí)現(xiàn)Mybatis插入數(shù)據(jù)時(shí)返回自增的主鍵Id
- 詳解mybatis插入數(shù)據(jù)后返回自增主鍵ID的問(wèn)題
- Mybatis-plus實(shí)現(xiàn)主鍵自增和自動(dòng)注入時(shí)間的示例代碼
- MyBatis插入時(shí)獲取自增主鍵方法
- 利用Java的MyBatis框架獲取MySQL中插入記錄時(shí)的自增主鍵
- MyBatis主鍵自增的兩種實(shí)現(xiàn)方法
相關(guān)文章
java Hibernate save()與persist()區(qū)別
本文章來(lái)給各位同學(xué)介紹一下Hibernate save()與persist()區(qū)別,希望此文章能對(duì)各位同學(xué)對(duì)于Hibernate save()與persist()有所理解2016-01-01Spring很常用的@Conditional注解的使用場(chǎng)景和源碼解析
今天要分享的是Spring的注解@Conditional,@Conditional是一個(gè)條件注解,它的作用是判斷Bean是否滿(mǎn)足條件,本文詳細(xì)介紹了@Conditional注解的使用場(chǎng)景和源碼,需要的朋友可以參考一下2023-04-045分鐘快速學(xué)會(huì)spring boot整合JdbcTemplate的方法
這篇文章主要給大家介紹了如何通過(guò)5分鐘快速學(xué)會(huì)spring boot整合JdbcTemplate的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用spring boot整合JdbcTemplate具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12SpringSecurity多認(rèn)證器配置多模式登錄自定義認(rèn)證器方式
這篇文章主要介紹了SpringSecurity多認(rèn)證器配置多模式登錄自定義認(rèn)證器方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04Java之關(guān)于基本數(shù)據(jù)類(lèi)型和引用數(shù)據(jù)類(lèi)型的存放位置
這篇文章主要介紹了Java之關(guān)于基本數(shù)據(jù)類(lèi)型和引用數(shù)據(jù)類(lèi)型的存放位置,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07java多線程實(shí)現(xiàn)服務(wù)器端與多客戶(hù)端之間的通信
本篇文章主要介紹了java多線程實(shí)現(xiàn)服務(wù)器端與多客戶(hù)端之間的通信,介紹了多線程來(lái)實(shí)現(xiàn)服務(wù)器與多線程之間的通信的基本步驟,有需要的小伙伴可以參考下。2016-10-10淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤
本篇文章主要介紹了淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01Java輸入學(xué)號(hào)、姓名、年齡并對(duì)其進(jìn)行輸出的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于Java輸入學(xué)號(hào)、姓名、年齡并對(duì)其進(jìn)行輸出的實(shí)現(xiàn)方法,在計(jì)算機(jī)編程中,輸出學(xué)號(hào)和姓名是一個(gè)常見(jiàn)的任務(wù),文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09