您的位置:首頁技術文章
文章詳情頁

java - 請問mybatis新增操作使用UUID 如何返回UUID

瀏覽:106日期:2024-02-13 18:19:59

問題描述

問題解答

回答1:

調用持久層前,自己生成一個UUID,放到對象里并且方法返回該UUID。

回答2:

dao接口定義 save 方法 時 嘗試 修改返回類型 為String 看看有沒有接收到。默認是返回影響行數的。如果配置了selectKey 可能會返回 selectKey的內容 。

在使用MyBatis做持久層時,insert語句默認是不返回記錄的主鍵值,而是返回插入的記錄條數;如果業務層需要得到記錄的主鍵時,可以通過配置的方式來完成這個功能

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

<insert parameterType='vo.Category'><selectKey resultType='java.lang.Short' order='BEFORE' keyProperty='id'>SELECT SEQ_TEST.NEXTVAL FROM DUAL</selectKey>insert into category (name_zh, parent_id,show_order, delete_status, description)values (#{nameZh,jdbcType=VARCHAR},#{parentId,jdbcType=SMALLINT},#{showOrder,jdbcType=SMALLINT},#{deleteStatus,jdbcType=BIT},#{description,jdbcType=VARCHAR})</insert>回答3:

mybatis默認返回的是影響的行數,要返回id要另外寫。如果是oracle的數據庫,uuid可以寫sys_guid()java - 請問mybatis新增操作使用UUID 如何返回UUID

如果是mysql的就要跟樓上說的一樣,先給一個id再保存

回答4:

不用在代碼中提前生成一個uuid,理解一下selectKey 中keyProperty屬性就可以解決這個問題。

java - 請問mybatis新增操作使用UUID 如何返回UUID

java - 請問mybatis新增操作使用UUID 如何返回UUID這樣在selectKey生成時,產生的UUID會set進當前對象中

標簽: java
相關文章:
国产综合久久一区二区三区