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>

猜你喜欢

转载自blog.csdn.net/touxian51552/article/details/85274246
今日推荐