MyBatis之insert主鍵自增和自定義主鍵詳解
一、實現(xiàn)描述
我們在寫程序時,時常會遇到這樣的問題:
插入一條數(shù)據(jù),但因有主鍵的存在,而有時候會報“違反唯一性約束”的錯誤,
下面呢,我們就來利用MyBatis來解決這個問題。
二、此文使用的數(shù)據(jù)庫為MySQL
如需要使用其他數(shù)據(jù)庫,請做適當(dāng)更改即可。
三、根據(jù)主鍵的自增
在MyBatis中進(jìn)行配置實現(xiàn),實現(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為主鍵字段,同時使用useGeneratedKeys屬性告訴MyBatis這個主鍵是否使用數(shù)據(jù)庫的內(nèi)置規(guī)則生成。
2、其中,在數(shù)據(jù)庫中設(shè)置id的自增規(guī)則,如下所示:
mysql>alter table t_role change id id int primary key auto_increment;
3、在上面配置中,我們指定了id列為自增字段,因此我們建立POJO,這樣的話,使用MyBatis的主鍵回填功能,實現(xiàn)正確的插入操作(無需設(shè)置id的值,MyBatis會用數(shù)據(jù)庫的設(shè)置進(jìn)行處理)。
4、測試:
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ī)則實現(xiàn)
實例如下:
<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ī)則的配置,其實上面的selectKey配置類似于數(shù)據(jù)庫中的觸發(fā)器,order=“BEFORE”規(guī)定了在執(zhí)行語句之前執(zhí)行newId的查找,然后在執(zhí)行插入語句。
這樣我們就利用自定義的主鍵規(guī)則實現(xiàn)了數(shù)據(jù)的新增。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Boot使用模板freemarker的示例代碼
本篇文章主要介紹了Spring Boot使用模板freemarker的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
Java中的SimpleDateFormat的線程安全問題詳解
這篇文章主要介紹了Java中的SimpleDateFormat的線程安全問題詳解,sonar 是一個代碼質(zhì)量管理工具,SonarQube是一個用于代碼質(zhì)量管理的開放平臺,為項目提供可視化報告, 連續(xù)追蹤項目質(zhì)量演化過程,需要的朋友可以參考下2024-01-01
詳解Java利用ExecutorService實現(xiàn)同步執(zhí)行大量線程
這篇文章主要介紹了Java利用ExecutorService實現(xiàn)同步執(zhí)行大量線程,ExecutorService可以維護(hù)我們的大量線程在操作臨界資源時的穩(wěn)定性。2017-03-03
被遺忘的Java關(guān)鍵字transient的使用詳解
在 Java 中,transient 是一個關(guān)鍵字,用于指定一個類的字段(成員變量)在序列化時應(yīng)該被忽略。本文將通過示例為大家簡單講講transient的使用,需要的可以參考一下2023-04-04

