亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用MyBatis怎么獲取插入記錄的自增長字段值

發布時間:2021-02-05 17:08:05 來源:億速云 閱讀:160 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關使用MyBatis怎么獲取插入記錄的自增長字段值,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

第一步:

    在Mybatis Mapper文件中添加屬性“useGeneratedKeys”和“keyProperty”,其中keyProperty是Java對象的屬性名!

<insert id="insert" parameterType="Spares" 
 useGeneratedKeys="true" keyProperty="id">
 insert into spares(spares_id,spares_name,
  spares_type_id,spares_spec)
 values(#{id},#{name},#{typeId},#{spec})
 </insert>

第二步:

    Mybatis執行完插入語句后,自動將自增長值賦值給對象Spares的屬性id。因此,可通過Spares對應的getter方法獲取!

 /**
 * 新增備件
 * @author hellostory
 * @param spares
 * @return
 */
 @RequestMapping(value = "/insert")
 @ResponseBody
 public JsonResponse insert(Spares spares) {
 int count = sparesService.insert(spares);
 System.out.println("共插入" + count + "條記錄!"
  + "\n剛剛插入記錄的主鍵自增長值為:" + spares.getId());

ps:mybatis返回插入數據的自增長id

今天測試反饋一個bug,現象是新注冊的用戶可以看到所有人的報告,老用戶沒問題,查看日志發現原來查詢的時候是新注冊的用戶的id為null,所以進行了全表有效數據查詢。 但是表的主鍵不允許為空,怎么會出現新的注冊用戶id為null呢?原因是在service層代碼直接將參數對象返回了,而xml沒有做任何配置。

具體的解決方案是在xml中的insert方法配置

useGeneratedKeys=”true” keyProperty=”registerId”

keyProperty值對應實體VO對象中的主鍵屬性

具體如下:

<code class="hljs java">@Override
  public Registers create(Registers r) {
    registersMapper.insert(r);
    return r;
  }</code>

registermapper.xml的insert方法如下:

<code class="hljs xml"><insert id="insert" keyproperty="registerId" parametertype="com.ciji.zzaservice.pojo.base.Registers" usegeneratedkeys="true">

執行正常的insert語句

</insert></code>

這樣在controller層就可以得到新插入數據的自增長主鍵了。

關于在xml中添加兩個屬性的意思,網上解釋如下:

useGeneratedKeys

(僅對insert有用)這會告訴MyBatis使用JDBC的getGeneratedKeys方法來取出由數據(比如:像MySQL和SQL Server這樣的數據庫管理系統的自動遞增字段)內部生成的主鍵。默認值:false。

keyProperty

(僅對insert有用)標記一個屬性,MyBatis會通過getGeneratedKeys或者通過insert語句的selectKey子元素設置它的值。默認:不設置。

上述就是小編為大家分享的使用MyBatis怎么獲取插入記錄的自增長字段值了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

元江| 隆尧县| 容城县| 平果县| 广宁县| 文登市| 霍林郭勒市| 景东| 盐亭县| 南康市| 阿鲁科尔沁旗| 阿巴嘎旗| 潮安县| 镇赉县| 临城县| 阿城市| 石阡县| 澎湖县| 翼城县| 固阳县| 双辽市| 凌源市| 丹东市| 启东市| 浙江省| 兴安盟| 汉沽区| 安新县| 安宁市| 岑溪市| 武冈市| 安达市| 丘北县| 临武县| 磐石市| 民丰县| 博罗县| 平谷区| 临邑县| 长白| 勃利县|