一、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。