博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mybatis入门教程(四)----参数之传入参数
阅读量:6947 次
发布时间:2019-06-27

本文共 2460 字,大约阅读时间需要 8 分钟。

hot3.png

3. MyBatis中的参数

        我个人理解,MyBatis中得参数分为传入参数和返回参数,传入参数就是在Mapper接口中定义abstract方法中传入的参数,返回参数就是该抽象方法的返回值。

在这儿我分别给大家介绍传入参数和返回参数,本篇博客就给大家介绍下传入参数,下面一篇日志专门介绍返回参数。

3.1 传入参数

Mybatis的Mapper文件中的select、insert、update、delete元素中有一个parameterType属性,用于对应的mapper接口方法接受的参数类型。

可以接受的参数类型有基本类型和复杂类型。

mapper接口方法一般接受一个参数,可以通过使用@Param注释将多个参数绑定到一个map做为输入参数。

3.1.1 简单类型

public Posts getPostsById(int id);

     
         select * from posts where id=#{id}     

对于简单数据类型,sql映射语句中直接#{变量名}这种方式引用就行了,其实这里的”变量名”可以是任意的。mapper接口方法传递过来的值,至于其叫什么名字其实是不可考也没必要知道的。

而且JAVA反射只能获取方法参数的类型,是无从得知方法参数的名字的。

比如上面这个示例中,使用#{id}来引用只是比较直观而已,使用其他名字来引用也是一样的。所以当在if元素中test传递的参数时,就必须要用_parameter来引用这个参数了。像这样:

    
         select * from posts         
         where id=#{id}                
         limit 0,1             

以上案例中的_parameter参数指代的是接口中相应方法的入参的名称。

3.1.2 对象类型

传入JAVA复杂对象类型的话,sql映射语句中就可以直接引用对象的属性名了,这里的属性名是实实在在的真实的名字,不是随意指定的。

Mapper中的接口方法:

public void addPosts(Posts posts);

sql映射:

    
        insert into posts(title,context) values(#{title},#{context})        
     

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

3.1.3 Map类型

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

Mapper接口:

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

 

SQL映射:

  update tb_user  set id = #{user.id,jdbcType=INTEGER},  ...  
    
  

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

3.1.4 集合类型

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接口:

public void batchUpdate(List
 list);

SQL映射:

   
    update posts set  badcount=3,goodcount=5 where id in   
           #{item.id}       

3.1.5 对象类型中的集合属性

对于单独传递的List或Array,在SQL映射文件中映射时,只能通过list或array来引用。但是如果对象类型有属性的类型为List或Array,则在sql映射文件的foreach元素中,可以直接使用属性名字来引用。

Mapper接口:

 

List
 selectByExample(UserExample example);

SQL映射:

  
    

转载于:https://my.oschina.net/KingPan/blog/266650

你可能感兴趣的文章
vim剪贴板小结
查看>>
Thinkpad ACCESS CONNECTIONS异常解决
查看>>
各行业对邮件服务器需求及解决方案
查看>>
linux软件管理与使用
查看>>
qt 使用样式设置渐变色背景
查看>>
ubuntu16.04 安装 操作 redis
查看>>
IIS启动网站出错的几个解决方法
查看>>
mysql对vachar排序的问题
查看>>
ASCII和Unicode编码
查看>>
什么事宏病毒,宏病毒的判断方法 ,宏病毒的防治和清除
查看>>
实战CGLib系列之proxy篇(五):接口生成器InterfaceMaker
查看>>
高并发编程-09-读写锁ReentrantReadWriteLock
查看>>
算法题!大家可以贡献答案哦!
查看>>
此文是2013年应届生实习时,集中培训班的最后,个人写给大家的话
查看>>
BYOD大势所趋 但仍有挑战
查看>>
JVM致命错误日志(hs_err_pid.log)解读
查看>>
需要具备的技能
查看>>
一个老司机工程师整理的自动化测试资料
查看>>
单机环境搭建Postgres-XC开发测试环境
查看>>
三: 推荐系统
查看>>