mybatis insert、update 、delete默認返回值解釋與如何設置返回表主鍵


在使用mybatis做持久層時,insert、update、delete,sql語句默認是不返回被操作記錄主鍵的,而是返回被操作記錄條數;

那么如果想要得到被操作記錄的主鍵,可以通過下面的配置方式獲取。

針對Sequence主鍵而言,在執行insert sql前必須指定一個主鍵值給要插入的記錄,如Oracle、DB2,可以采用如下配置方式:

<insert id="save" parameterType="user">

<selectKey resultType="java.lang.Short" order="BEFORE" keyProperty="id">

SELECT SEQ_TEST.NEXTVAL FROM DUAL

</selectKey>

insert into user(name, age,password) values (#{name},#{age},#{password})

</insert>

針對自增主鍵的表,在插入時不需要主鍵,而是在插入過程自動獲取一個自增的主鍵,比如MySQL,可以采用如下兩種配置方式:

 

<insert id="save" parameterType="user" useGeneratedKeys="true" keyProperty="id">

insert into user(name, age,password) values (#{name},#{age},#{password})

</insert>

 或

<insert id="save" parameterType="user">

<selectKey resultType="java.lang.Short" order="AFTER" keyProperty="id">

SELECT LAST_INSERT_ID() AS id

</selectKey>

insert into user(name, age,password) values (#{name},#{age},#{password})

</insert>

 在插入操作完成之后,參數user的id屬性就已經被賦值了,再在邏輯層利用user.getId()獲取就好。

參考文章地址:http://blog.csdn.net/jbgtwang/article/details/7307687


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM