Java通用Mapper UUID簡單示例
#通用 Mapper UUID 簡單示例
##不可回寫的 UUID
通用 Mapper 中對 UUID 的用法主要提到了一種專有的寫法,如下寫法:
@GeneratedValue(generator = "UUID")
這種方式實現(xiàn)很容易理解,就是在你 insert 之前,調(diào)用 UUID 的公共方法在<bind> 標簽中生成了一個值,插入到了數(shù)據(jù)庫,由于這個值是臨時的,并沒有set到對象,因此這種方式是不支持回寫的。
由于回寫方式很常見,因此用這種方式很難滿足要求。
而且在文檔中也提到了一種可以回寫的方式,由于沒有提供例子,導致很多人不理解或者嘗試失敗,因此很早就有必要寫一篇如何使用可回寫 UUID 的方式(我曾經(jīng)遠程協(xié)助一個朋友解決過這個問題,這個朋友答應我把自己的用法寫下來分享給大家,可惜食言了)。
##可回寫的 UUID
最簡單的可回寫 UUID 方式就是像 Oracle 序列那樣直接寫一個返回 UUID 的 SQL 就能實現(xiàn),這是第一種寫法:
@Id @GeneratedValue(strategy = GenerationType.IDENTITY,generator = "select uuid()") private String id;
使用這種方式的時候必須注意,由于是執(zhí)行 SQL,所以底層是使用<selectKey> 實現(xiàn)的,并且因為需要先得到 UUID 的值才能插入數(shù)據(jù)庫,因此還需要配置ORDER屬性,使用 Java 方式配置時,用下面的方式進行配置:
Config config = new Config();
// 其他配置
// 主鍵自增回寫方法執(zhí)行順序,默認AFTER,可選值為(BEFORE|AFTER)
config.setOrder("BEFORE");
mapperHelper.setConfig(config);
使用 Spring 方式進行配置時如下:
<bean class="tk.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.isea533.mybatis.mapper"/>
<property name="properties">
<value>
mappers=tk.mybatis.mapper.common.Mapper
ORDER=BEFORE
</value>
</property>
</bean>
注意是增加ORDER=BEFORE這一行,如果你還有其他配置,都可以按這種方式一行一個key=value。
這么配置以后就可以正確的獲取 UUID 的值了。
##任意類型的主鍵回寫值
你可能沒注意到上面 UUID 類型的主鍵中,id 屬性的類型是String,因為select uuid() 返回的字符串,所以 Java 中的類型要和數(shù)據(jù)庫類型匹配。
因此,如果你使用一個select myId() 函數(shù)返回一個自定義類型的主鍵值,你需要讓 Java 中的類型和這個匹配。
##通用主鍵 SQL 配置
如果你每一個實體類中都有一個id 屬性,并且配置的注解都一樣,都執(zhí)行同樣的 SQL 去返回值。如果都去配置這個注解會很麻煩。想要解決這種重復性配置,最簡單的方式就是提取基類,讓使用相同方式主鍵策略的實體類繼承同一個基類就能解決。
解決方案看這里: https://github.com/guozilanTK/base/tree/master/base-id
但是如果你需要適用不同的數(shù)據(jù)庫,這種方式麻煩點的解決辦法就是針對不同的數(shù)據(jù)庫創(chuàng)建不同的基類,放在不同的項目中,但是使用相同的包名,具體應用到生產(chǎn)環(huán)境時使用對應數(shù)據(jù)庫的基類 jar 包就可以。除此之外還有一種方式,這種方式就是使用 IDENTITY,這個參數(shù)用于配置取回主鍵的方式。
默認提供的IDENTITY 可選值參考文檔 GenerationType.IDENTITY 。
這個參數(shù)除了這些可選值外,還可以是可以執(zhí)行的 SQL,也就是說最前面的配置方式可以改為:
@Id @GeneratedValue(strategy = GenerationType.IDENTITY) private String id;
在 Java 方式中用下面的方式進行配置:
Config config = new Config();
// 其他配置
config.setIDENTITY("select uuid()");
// 主鍵自增回寫方法執(zhí)行順序,默認AFTER,可選值為(BEFORE|AFTER)
config.setOrder("BEFORE");
mapperHelper.setConfig(config);
使用 Spring 方式進行配置時如下:
<bean class="tk.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.isea533.mybatis.mapper"/>
<property name="properties">
<value>
mappers=tk.mybatis.mapper.common.Mapper
IDENTITY=select uuid()
ORDER=BEFORE
</value>
</property>
</bean>
這里仍然要注意設置ORDER=BEFORE,如果你用IDENTITY 提供的那些可選參數(shù),就不要設置(默認為AFTER),可選參數(shù)中仍然是針對的數(shù)據(jù)庫支持自增的情況,那些情況仍然是插入數(shù)據(jù)庫后才會有主鍵值,這點一定要明白!
在這種情況下,如果換了數(shù)據(jù)庫,只需要修改一下配置就能解決,例如 SQL SERVER 的:
IDENTITY=select replace(newid(), '-', '')
##小結
關于 UUID 的內(nèi)容就上面這些,還需要提醒一點的就是由于ORDER是一個全局的配置,所以使用時要注意保證所有主鍵方式都是一致的ORDER方式,主鍵自增的時候使用@GeneratedValue(generator = "JDBC") 這種方式通過 JDBC 接口去獲取返回值更好。當然使用批量插入時,MySql 支持多主鍵回寫,但是 SqlServer 僅能返回最后一個插入的主鍵,所以選擇使用某種方式時,一定要有所了解,做好測試,避免數(shù)據(jù)庫差異帶來的問題。
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接
相關文章
如何使用Spring+redis實現(xiàn)對session的分布式管理
本篇文章主要介紹了如何使用Spring+redis實現(xiàn)對session的分布式管理,本文主要是在Spring中實現(xiàn)分布式session,采用redis對session進行持久化管理,感興趣的小伙伴們可以參考一下2018-06-06
Java動態(tài)代理的兩種實現(xiàn)方式詳解【附相關jar文件下載】
這篇文章主要介紹了Java動態(tài)代理的兩種實現(xiàn)方式,結合實例形式分析了java動態(tài)代理的相關原理、實現(xiàn)方法與操作技巧,并附帶相關jar文件供讀者下載,需要的朋友可以參考下2019-03-03
Spring?Boot集成Milvus快速入門demo示例詳解
Milvus是一種高性能向量數(shù)據(jù)庫,支持從筆記本到大型分布式系統(tǒng)的多環(huán)境運行,它以開源和云服務形式提供,是LFAI & Data Foundation的項目,采用Apache 2.0許可,Milvus特別支持高并行化和解耦的系統(tǒng)架構,使其能夠隨數(shù)據(jù)增長而擴展,支持各種復雜搜索功能,滿足企業(yè)級AI應用需求2024-09-09
獲取JPEGImageEncoder和JPEGCode這兩個類的方法
下面小編就為大家?guī)硪黄@取JPEGImageEncoder和JPEGCode這兩個類的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
Java實現(xiàn)Kafka生產(chǎn)者和消費者的示例
這篇文章主要介紹了Java實現(xiàn)Kafka生產(chǎn)者和消費者的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02

