Mybatis

一、Mybatis简介

mybatis封装了jdbc的持久层框架,前身为ibatis,在配置文件中编写sql,是不完全orm(Object Relational Mapping)映射框架。

1、支持普通sql查询

2、高级映射

3、存储过程

4、消除了几乎所有jdbc代码和参数的手工设置以及结果集的检索

二、Mapper代理开发的方式

Mapper代理开发方式就是开发mapper接口(相当于dao接口)

1、mapper接口的类地址要和mapper映射文件的namespace一致

2、mapper接口的方法名称要和mapper映射文件的id一致

3、mapper接口的方法参数类型要和mapper映射文件t的parameterType一致

4、mapper接口的方法返回值类型要和 mapper映射文件的resultType一致

三样东西,mapper接口,一个全局配置文件,一个映射文件,mapper接口的名称要和映射文件的名称相同。

mapper接口,userMapper.java

映射文件,UserMapper.xml

三、输入映射

 3.1、传递简单类型,八大基本类型,比如int类型

findUserById:根据id进行查询对应user,那么传入的参数就应该是int类型的值。

 

3.2、传递pojo(代表正常的对象,比如user的javabean对象)    

insertUser:就是传递的User这个对象。

 注意:在使用pojo之后,#{xxx}。 xxx表示pojo对象中的属性名。

3.3、传递包装pojo(其中放置的为集合,对象引用等)

什么是包装pojo?比如

queryUserList

 注意:user.username这个属性的获取,因为UserQueryVO是一个包装pojo,其中有user的引用。而user中又有username的属性,那么这样一层层取过来用即可。

3.4、传递hashmap

          注意:hashmap使用的是别名,mybatis中内置了。

四、输出映射

4.1resultType

查询出来的结果的列名需要对应我们编写的输出映射类型中的属性名,如果不匹配,则不能完成映射,那么查询出来的结果也不能如愿的放入对应的对象中去。

4.2resultMap

查询出来的结果的列名不用对应我们编写的输出映射类型中的属性名,也能够完成映射。此时就需要resultMap来做这个事情了,使用一个案例来说明

         案例1.:查询的sql语句使用了别名,如何将其与对应的对象的属性进行映射?使用resultMap来完成   

 

 其实就是通过resultMap这个中介,来帮我们完成映射,本来是不能够成功映射的,因为属性名和列名不同,但是中间有了resultMap帮我们完成这个映射。就可以达到这种效果了,不过使用resultMap是比resultType更为繁琐一点,但是也有其优点,在进行高级映射时,更多的是使用resultMap。

 

参考博客:https://www.cnblogs.com/whgk/p/6718979.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值