1. 程式人生 > >Mybatis獲取最新插入資料的id

Mybatis獲取最新插入資料的id

Mybatis獲取最新插入資料的id

原始方法

讀取最後一條的插入資料,但這樣會造成如果兩條資料同時插入,會併發出現錯誤

SELECT * FROM admin_users where 1=1 ORDER BY id desc  LIMIT 1

select MAX(id) from admin_users


使用useGeneratedKeys

useGeneratedKeys 取值範圍true|false 預設值是:false。
含義:設定是否使用JDBC的getGenereatedKeys方法獲取主鍵並賦值到keyProperty設定的領域模型屬性中。
直接在註冊完成後取id就行

 <!--表名-->
    <sql id="tableName">IMS_BS_BOOK_COPY</sql>
    <!--欄位-->
    <sql id="insertField">PRICE,ENTITY_ID,CODE,ADD_TIME,STATUS,REASON,GRID_CODE,STALL_CODE,CASE_CODE,ORDER_CODE</sql>
    <!--欄位值-->
    <sql id="insertFieldValue">#{PRICE},#{ENTITY_ID}
,#{CODE},#{ADD_TIME},#{STATUS},#{REASON},#{GRID_CODE},#{STALL_CODE},#{CASE_CODE},#{ORDER_CODE}</sql> <!--新增--> <insert id="save" parameterType="pd" useGeneratedKeys="true" keyProperty="id">insert into <include refid="tableName"/>( <include refid="insertField"
/>) values ( <include refid="insertFieldValue"/>) </insert>