MyBatis之insert主鍵自增和自定義主鍵詳解
一、實(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的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2017-10-10Java中的SimpleDateFormat的線程安全問題詳解
這篇文章主要介紹了Java中的SimpleDateFormat的線程安全問題詳解,sonar 是一個(gè)代碼質(zhì)量管理工具,SonarQube是一個(gè)用于代碼質(zhì)量管理的開放平臺(tái),為項(xiàng)目提供可視化報(bào)告, 連續(xù)追蹤項(xiàng)目質(zhì)量演化過程,需要的朋友可以參考下2024-01-01Java拼接字符串時(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í)行大量線程,ExecutorService可以維護(hù)我們的大量線程在操作臨界資源時(shí)的穩(wěn)定性。2017-03-03被遺忘的Java關(guān)鍵字transient的使用詳解
在 Java 中,transient 是一個(gè)關(guān)鍵字,用于指定一個(gè)類的字段(成員變量)在序列化時(shí)應(yīng)該被忽略。本文將通過示例為大家簡(jiǎn)單講講transient的使用,需要的可以參考一下2023-04-04Spring Data Redis對(duì)象緩存序列化問題解決
相信在項(xiàng)目中,你一定是經(jīng)常使用Redis,在使用時(shí),有沒有遇到同我一樣,對(duì)象緩存序列化問題的呢,本文主要介紹了Spring Data Redis對(duì)象緩存序列化問題解決,感興趣的可以了解一下2024-01-01SpringBoot在項(xiàng)目中訪問靜態(tài)資源步驟分析
今天在玩SpringBoot的demo的時(shí)候,放了張圖片在resources目錄下,啟動(dòng)區(qū)訪問的時(shí)候,突然好奇是識(shí)別哪些文件夾來(lái)展示靜態(tài)資源的, 為什么有時(shí)候放的文件夾不能顯示,有的卻可以2023-01-01