MyBatis基于XML的详细使用-参数、返回结果 处理

1、参数的取值方式
在xml文件中编写sql语句的时候有两种取值的方式,分别是#{}和${}。
在这里插入图片描述
注意:这里推荐使用#{}的方式,可以有效的防止sql注入问题。
2、select的参数传递
1.单个参数:
在这里插入图片描述
不管多少个参数最好在参数前加上@param注解,为其取一个别名
在这里插入图片描述
2.多个参数查询:
在这里插入图片描述

在这里插入图片描述
3.单个javaBean参数的方式:
在这里插入图片描述
在这里插入图片描述
4.javaBean多个参数的方式:
在这里插入图片描述
在这里插入图片描述
5.集合参数的方式:
在这里插入图片描述
在这里插入图片描述
6.采用数组的方式:
在这里插入图片描述
在这里插入图片描述
7.map参数
和javaBean的参数传递是一样。
一般情况下:
请求进来的参数 和pojo对应,就用pojo
请求进来的参数 没有和pojo对应,就用map
请求进来的参数 没有和pojo对应上,但是使用频率很高,就用TO、DTO(就是单独为这些参数创建一个对应的javaBean出来,使参数传递更规范、更重用)

除了上面这几种方式:还有别的方式可以进行处理
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
总结:在进行参数处理的时候,个人建议都要在接口声明参数的时候为其加上一个@param(“”)注解,为其取一个别名,提高代码的可读性。
3、处理集合返回结果

在这里插入图片描述
在这里插入图片描述
注意:处理集合返回结果的时候必须声明一个resultMap,原则上一个数据表对应一个resultMap,不管pojo对象中的属性名和数据库表中的字段名是否完全一样,都应该设置,其中的 是对数据库主键的标识。extends属性是指继承另外一个resultMap结果集。如果多个resultMap有重复映射,可以声明父resultMap,将公共的映射提取出来, 可以减少子resultMap的映射冗余

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis中的缓存机制可以帮助我们提高数据访问的性能。Mybatis提供了两种缓存机制:一级缓存和二级缓存。 一级缓存是Mybatis默认开启的,它是基于SqlSession的缓存,也就是说在同一个SqlSession中,如果多次查询同样的SQL语句并且参数也相同,那么Mybatis会直接从缓存中获取结果,而不再去查询数据库。一级缓存的生命周期与SqlSession相同,当SqlSession关闭时,一级缓存也会被清空。 二级缓存是基于namespace级别的缓存,它可以跨SqlSession共享数据。当开启了二级缓存后,在同一个namespace中执行相同的SQL语句时,Mybatis会先从二级缓存中查找数据,如果找到了就直接返回结果。如果没有找到,则会去查询数据库,并将查询结果放入到二级缓存中。二级缓存的生命周期与Mapper的namespace相同,当应用重启或者刷新了Mapper配置文件时,二级缓存会被清空。 对于一级缓存的配置,我们无需做任何配置,因为它是默认开启的。而对于二级缓存的配置,我们需要在Mapper配置文件中添加相应的配置项。例如: ```xml <mapper namespace="com.example.UserMapper"> <cache type="org.apache.ibatis.cache.impl.PerpetualCache"/> </mapper> ``` 上述配置中,`type`属性指定了具体使用的缓存实现类,这里使用的是PerpetualCache,它是Mybatis提供的默认实现。 除了使用Mybatis自带的缓存实现,我们还可以使用第三方缓存框架,比如Ehcache、Redis等。在这种情况下,我们需要在Mapper配置文件中指定具体使用的缓存实现类,并配置相应的缓存参数。 需要注意的是,缓存虽然可以提高查询性能,但也会带来数据一致性的问题。当我们对数据库进行增删改操作时,需要及时清空对应的缓存,以保证数据的准确性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值