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

Mybatis-plus插入數(shù)據(jù)遇到主鍵沒(méi)有默認(rèn)值的情況

 更新時(shí)間:2023年11月03日 15:24:05   作者:讓丄帝愛(ài)伱  
這篇文章主要介紹了Mybatis-plus插入數(shù)據(jù)遇到主鍵沒(méi)有默認(rèn)值的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Mybatis-plus插入數(shù)據(jù)遇到主鍵沒(méi)默認(rèn)值

新增數(shù)據(jù)時(shí)報(bào)

java.sql.SQLException: Field 'id' doesn't have a default value

mybatis-plus的insert方法,在底層會(huì)默認(rèn)生成一個(gè)Long類型的UUID,這就導(dǎo)致跟數(shù)據(jù)庫(kù)里面類型不一致,把數(shù)據(jù)庫(kù)默認(rèn)自增的主鍵給禁了

主鍵生成方式類型如下(IdType):

AUTO(0, "數(shù)據(jù)庫(kù)ID自增"),
INPUT(1, "用戶輸入ID"),
ID_WORKER(2, "全局唯一ID"),
UUID(3, "全局唯一ID"),
NONE(4, "該類型為未設(shè)置主鍵類型"),
ID_WORKER_STR(5, "字符串全局唯一ID");

設(shè)置主鍵的生成方式

@TableId(value = "id",type = IdType.INPUT) // 主鍵手動(dòng)輸入

mybatis-plus插入數(shù)據(jù)時(shí),關(guān)于id沒(méi)有賦值,系統(tǒng)自動(dòng)賦值,并報(bào)錯(cuò)Could not set property ‘id‘ of ‘***‘ with value

趕時(shí)間的同學(xué)可以直接看文章最后的結(jié)果

創(chuàng)建了一張表,表里面有id字段,但是并沒(méi)有聲明它為主鍵

對(duì)應(yīng)java實(shí)體類為

然后開(kāi)始inset,隨便寫(xiě)個(gè)偽代碼

User user = new User();
user.setId("");
user.setName("測(cè)試");
this.insert(user);

然后就報(bào)錯(cuò)了,一看報(bào)錯(cuò)信息是

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException:
Could not set property ‘id’ of 'class User ’ with value ‘1278867511785242626’
Cause: java.lang.IllegalArgumentException: argument type mismatch

what??

我并沒(méi)有設(shè)置id啊,看著這有規(guī)則數(shù)字,很像是mybatis-plus自動(dòng)生成的主鍵值

然后就翻了翻mybatis-plus的大致源碼,找到idType類

看到mybatis-plus有這5中主鍵生成類型,一般對(duì)應(yīng)我們數(shù)據(jù)庫(kù)表中id的生成類型

比如我設(shè)置我得實(shí)體類id的生成類型為uuid

以上一般是我們的正常操作

現(xiàn)在的我不想在這個(gè)表中建立主鍵,我想插入數(shù)據(jù)的時(shí)候,先不塞id的值,我就是想寫(xiě)bug(??開(kāi)玩笑?。?,這樣怎么弄呢

我不添加@TableId注解,不設(shè)置id的類型不行了嗎,答案是不行的

如果你的實(shí)體類中有字段名定義為了“id”,mybatis-plus就默認(rèn)你這個(gè)字段是主鍵,就算你不定義它的生成類型,mybatis-plus在自動(dòng)裝載的時(shí)候會(huì)幫你把id設(shè)置為默認(rèn)類型,而默認(rèn)的idType就是ID_WORKER,全局唯一

那好,我加上主鍵@TableId

既然我這個(gè)表沒(méi)有主鍵,我也不想塞值進(jìn)去,那我把實(shí)體里面的id類型設(shè)置為

@TableId(type = IdType.NONE)
	private String id;

這個(gè)行不行呢,答案還是是不行的,如下

找到TableInfoHelper 這個(gè)類,里面有初始化table的方法 initTableId

里面進(jìn)行了判斷,如果idType為NONE,還是會(huì)把id的類型設(shè)置成全局默認(rèn)類型ID-WORKER

哈哈,由此可以看出mybatis-plus怕我們忘記設(shè)置主鍵id真是操碎了心啊

好了,上面5中id生成的類型只有input看著可以滿足我們的需求了

這個(gè)顧名思義就是用戶塞什么值就是什么值

我們把idType設(shè)置為

@TableId(type = IdType.INPUT)
private String id;

這樣我們就可以隨意的寫(xiě)入id任何值了,。

總結(jié)

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

相關(guān)文章

最新評(píng)論