1. resultMpa 与 resultType
1.1 resultType
使用mybatis进行增 删 改操作时,可以不设置返回类型,默认是返回受影响的行数
然而在使用 MyBatis 进行查询操作时候,一定要设置至少两个属性:
- id属性:用于标识实现接口中的那个方法;
- 结果映射属性:结果映射有两种实现标签:resultMap 和 resultType
前面因为我们数据库中的表的字段名称和对象的属性名称是一摸一样的,所以就都使用了 resultType 进行映射 :
以userinfo 表为列:
resultType 优点是使⽤⽅便,直接定义到某个实体类即可。
对象关系能够一对一的映射上,如果在字段与属性名称不一致时候,就需要使用 resultMap 进行相应的设置
1.2 resultMap
返回字典映射:resultMap
resultMap 使⽤场景:
- 字段名称和程序中的属性名不同的情况,可使⽤ resultMap 配置映射;
- ⼀对⼀和⼀对多关系可以使⽤ resultMap 映射并查询数据
如果出现字段名称与属性名称不一致时候可以使用resultMap配置映射,具体操作如下:
mapper.xml代码如下:
通过单元测试尝试获取查询的username:
发现是获取不到的(null):
这个时候就可以使⽤ resultMap 了,resultMap 的使用如下:
手动设置了数据库中的username字段和对象的name属性映射,此时就可以正确获取到结果了:
此时就能成功获取:
2. 多表查询
2.1 ⼀对⼀
讲解一对一时候,假设数据库中的一篇文章对应一个作者:
同时在article表的实体类要实现一个user表对应的外键:
在使用多表查询时候,一定要设置好两张表的resultMap :
user表的resultMap:
article表的resultMap:
⼀对⼀映射要使用 association 标签 :
同时需要设置columnPrefix ;如果省略,并且恰好两个表中如果有相同的字段,那么就会导致查询出错,示例如下:
userinfo 表中有 id 字段,articleinfo 中也有⼀个 id 字段,会导致查询出错结果如下:
此时假设文章的id是1,用户id是2,查询出来的用户id结果就会被先查询出来的文章id 1 覆盖,导致显示的用户id为1,实际上为2,而出错;
(两张表字段相同的情况下重名的字段会被第一次查询出来的字段值覆盖)
此时为了解决这个问题就需要使用 columnPrefix 来设置表的前缀了,避免出现字段重名的情况:
并且在进行多表查询时候需要写对多表查询的SQL(left join…on…):
ArticleMapper接口如下:
xml如下:
<select id="getArticleById" resultMap="BaseMap">
select a.*,u.id u_id,u.username u_username,u.password u_password from articleinfo a left join userinfo u on a.uid=u.id where a.id=#{id}
</select>
单元测试:
- 多表查询(一对一部分)over ~
2.2 一对多
在学习了一对一部分之后,mybatis实现一对多查询就很容易理解啦~
这里依旧以文章表和用户表举列,一个用户可以拥有多篇文章,所以用户与文章的关系就是一对多;
在实现用户实体类的时候就需要加上文章表集合(list),表示用户与文章为一对多的关系;
mapper接口里面实现根据用户id查询用户以及对应拥有的文章
然后在对应的xml文件中实现对应的一对多SQL:
重点:实现resultMap:
注意:columnPrefix填的前缀是啥,对应的SQL书写也应该遵守:
执行单元测试:
根据用户id查询用户信息成功:
以及查询到用户对应的文章信息:
-
多表查询,一对多查询成功 ~
-
over ~