Mybatis的输入映射

前言:Mybatis的配置文件中的select,insert,update,delete有一个属性parameter来接收mapper接口方法中的参数。可以接收的类型有简单类型和复杂类型,但是只能是一个参数。这个属性是可选的,因为Mybatis可以通过TypeHandler来判断传入的参数类型,默认值是unset.

1.各种java的基本数据类型。常用的有int,String,Data等等。

eg:

User selectById(Integer id);
<select id="selectById" parameterType="int" resultMap="com.caoal.vo.User">
select * from where id=#{id}
</select>

用#{变量名}来取值,这里的变量名是任意的,可以用value或者是其它的什么值,这里用id是为了便于理解,并不存在什么对应关系的。因为java反射主只能够得到方法参数的类型,而无从知道参数的名字的。当在动态sql中的if语句中的test传递参数时,就必须要用_parameter来传递参数了(OGNL表达式),如果你传入id就会报错。

2.各种类型的pojo,.取值用#{属性名}。这里的属性名是和传入的pojo中的属性名一一对应的,不是你随意命名的。

int isertUser(User u);
<insert id="insert	User" parameterType="User">
insert into TBUser(name,sex) values(#{name},#{sex})
</insert>

如果要在if元素中测试传入的user参数,仍然要使用_parameter来引用传递进来的实际参数,因为传递进来的User对象的名字是不可考的。如果测试对象的属性,则直接引用属性名字就可以了。

测试user对象:

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

测试user对象的属性:

1
< if test = "name != null" >

3.Map

传入map类型,直接通过#{keyname}就可以引用到键对应的值。使用@param注释的多个参数值也会组装成一个map数据结构,和直接传递map进来没有区别。

mapper接口:

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

sql映射:

<update id="updateByExample" parameterType="map" >  
update tb_user  set id = #{user.id},   ...   
<if test="_parameter != null" >     
<include refid="Update_By_Example_Where_Clause" />   
</if>
</update>

注意这里测试传递进来的map是否为空,仍然使用_parameter

4.List类型,用<foreach>语句来进行迭代。

可以传递一个List或Array类型的对象作为参数,MyBatis会自动的将List或Array对象包装到一个Map对象中,List类型对象会使用list作为键名,而Array对象会用array作为键名。集合类型通常用于构造IN条件,sql映射文件中使用foreach元素来遍历List或Array元素。

mapper接口:

User selectUserInList(List<Interger> idlist);

sql动态语句映射:

<select id="selectUserInList" resultType="User">   
SELECT *   FROM USER   WHERE ID in   
<foreach item="item" index="index" collection="list" open="(" separator="," close=")">         
#{item}  
</foreach> 
</select>

5.对象类型中的集合属性

对于单独传递的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元素



 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值