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

Mybatis如何獲取最新插入數(shù)據(jù)的id

 更新時間:2022年01月15日 09:22:44   作者:touxianya  
這篇文章主要介紹了Mybatis如何獲取最新插入數(shù)據(jù)的id,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

獲取最新插入數(shù)據(jù)的id

原始方法

讀取最后一條的插入數(shù)據(jù),但這樣會造成如果兩條數(shù)據(jù)同時插入,會并發(fā)出現(xiàn)錯誤

SELECT * FROM admin_users where 1=1 ORDER BY id desc ?LIMIT 1
select MAX(id) from admin_users

使用useGeneratedKeys

useGeneratedKeys 取值范圍true|false 默認值是:false。

含義:設(shè)置是否使用JDBC的getGenereatedKeys方法獲取主鍵并賦值到keyProperty設(shè)置的領(lǐng)域模型屬性中。

直接在注冊完成后取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>

根據(jù)時間查詢最新一條數(shù)據(jù)

第一種的xml配置根據(jù)最新的插入時間

<select id="selectLast" resultMap="BaseResultMap" parameterType="java.lang.String">
? ? ? ? SELECT
? ? ? ? *
? ? ? ? from 表名
? ? ? ? where createtime=(select max(createtime) from 表名 where
? ? ? ? 字段名=#{參數(shù)名,jdbcType=VARCHAR} )
? ? </select>

第二種的xml配置根據(jù)ownum

select id="selectLast" resultMap="BaseResultMap" parameterType="java.lang.String">
? ? ? ? ? ? select t.*,rownum from
? ? ? ? ? ? (select * from 表名 ?where ?字段名=#{參數(shù)名,jdbcType=VARCHAR}?
? ? ? ? ? ? order by createtime desc)t ? where rownum=1
? ? </select>

不足之處請大家評論指出。以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論