日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

mybatis mapper.xml入参

發布時間:2024/2/28 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybatis mapper.xml入参 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Mybatis的Mapper文件中的select、insert、update、delete元素中有一個parameterType屬性,用于對應的mapper接口方法接受的參數類型。

可以接受的參數類型有基本類型和復雜類型。

mapper接口方法一般接受一個參數,可以通過使用@Param注釋將多個參數綁定到一個map做為輸入參數。

  • 簡單數據類型

    mapper接口方法:

    1 User selectByPrimaryKey(Integer id);

    sql映射:

    1 2 3 4 5 6 <select?id="selectByPrimaryKey"?resultMap="BaseResultMap"?parameterType="java.lang.Integer"?> ??select ??<include?refid="Base_Column_List"?/> ??from base.tb_user ??where id = #{id,jdbcType=INTEGER} </select>

    對于簡單數據類型,sql映射語句中直接#{變量名}這種方式引用就行了,其實這里的"變量名"可以是任意的。mapper接口方法傳遞過來的值,至于其叫什么名字其實是不可考也沒必要知道的。
    而且JAVA反射只能獲取方法參數的類型,是無從得知方法參數的名字的。

    比如上面這個示例中,使用#{id}來引用只是比較直觀而已,使用其他名字來引用也是一樣的。所以當在if元素中test傳遞的參數時,就必須要用_parameter來引用這個參數了。像這樣:

    1 2 3 4 5 6 7 8 <select?id="selectByPrimaryKey"?resultMap="BaseResultMap"?parameterType="java.lang.Integer"?> ??select ??<include?refid="Base_Column_List"?/> ??from tb_user ??<if?test="_parameter != 0"> ??where id = #{id,jdbcType=INTEGER} ??</if> </select>

    如果test測試條件中使用id就會提示錯誤,因為這個參數其實沒有名字,只是一個值或引用而已,只能使用_parameter來引用。

  • 對象類型

    傳入JAVA復雜對象類型的話,sql映射語句中就可以直接引用對象的屬性名了,這里的屬性名是實實在在的真實的名字,不是隨意指定的。
    mapper接口方法:

    1 int?insert(User user);

    sql映射:

    1 2 3 <insert?id="insert"?parameterType="User"?useGeneratedKeys="true"?keyProperty="id"> ??insert into tb_user (name, sex) ??values (#{name,jdbcType=CHAR}, #{sex,jdbcType=CHAR})

    雖然可以明確的引用對象的屬性名了,但如果要在if元素中測試傳入的user參數,仍然要使用_parameter來引用傳遞進來的實際參數,因為傳遞進來的User對象的名字是不可考的。如果測試對象的屬性,則直接引用屬性名字就可以了。

    測試user對象:

    1 <if?test="_parameter != null">

    測試user對象的屬性:

    1 <if?test="name != null">
  • map類型

    傳入map類型,直接通過#{keyname}就可以引用到鍵對應的值。使用@param注釋的多個參數值也會組裝成一個map數據結構,和直接傳遞map進來沒有區別。

    mapper接口:

    1 int?updateByExample(@Param("user") User user,?@Param("example") UserExample example);

    sql映射:

    1 2 3 4 5 6 7 <update?id="updateByExample"?parameterType="map"?> ??update tb_user ??set id = #{user.id,jdbcType=INTEGER}, ??... ??<if?test="_parameter != null"?> ????<include?refid="Update_By_Example_Where_Clause"?/> ??</if>

    注意這里測試傳遞進來的map是否為空,仍然使用_parameter

  • 集合類型

    You can pass a List instance or an Array to MyBatis as a parameter object. When you do, MyBatis will automatically wrap it in a Map, and key it by name. List instances will be keyed to the name "list" and array instances will be keyed to the name "array".

    可以傳遞一個List或Array類型的對象作為參數,MyBatis會自動的將List或Array對象包裝到一個Map對象中,List類型對象會使用list作為鍵名,而Array對象會用array作為鍵名。

    集合類型通常用于構造IN條件,sql映射文件中使用foreach元素來遍歷List或Array元素。

    mapper接口:

    1 User selectUserInList(List<Interger> idlist);

    sql動態語句映射:

    1 2 3 4 5 6 7 8 9 <select?id="selectUserInList"?resultType="User"> ??SELECT * ??FROM USER ??WHERE ID in ??<foreach?item="item"?index="index"?collection="list" ??????open="("?separator=","?close=")"> ????????#{item} ??</foreach> </select>
  • 對象類型中的集合屬性

    對于單獨傳遞的List或Array,在SQL映射文件中映射時,只能通過list或array來引用。但是如果對象類型有屬性的類型為List或Array,則在sql映射文件的foreach元素中,可以直接使用屬性名字來引用。
    mapper接口:

    1 List<User> selectByExample(UserExample example);

    sql映射文件:

    1 2 3 <where?> ??<foreach?collection="oredCriteria"?item="criteria"?separator="or"?> ????<if?test="criteria.valid"?>

    在這里,UserExample有一個屬性叫oredCriteria,其類型為List,所以在foreach元素里直接用屬性名oredCriteria引用這個List即可。

    item="criteria"表示使用criteria這個名字引用每一個集合中的每一個List或Array元素

  • 總結

    以上是生活随笔為你收集整理的mybatis mapper.xml入参的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。