mybatis混淆概念

Posted afei1759

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis混淆概念相关的知识,希望对你有一定的参考价值。

1、resultMap与resultType
<mapper namespace="com.dao.FilmMapper">
  <resultMap id="BaseResultMap" type="com.entity.Film">
    ...Film类属性/属性别名对应数据库字段
  </resultMap >
  <select id="selectAll" resultMap="BaseResultMap">
    ...
  </select>
  <select id="selectAll" resultType="com.entity.Film">
    ...
  </select>
</mapper>
 
(1)resultMap和resultType区别:当配置resultType时,就不需要配置resultMap,因为resultType跟resultMap不能同时存在,看似resultType方便,但是会被受限制,没有resultMap开放多。 相同点:都是表示查询结果集的类型。 不同点:resultMap需要手动配置映射关系,而resultType是直接指定返回数据为java类型或者自定义的实体类型,查询结果集的列名/别名必须和实体属性名称一致且大小写不敏感,即resultType=实体类、java基本类型数据:列名/别名、实体属性名大小写可以忽略;resultType=java.util.Map,则存值形式为(查询结果集的列名/别名,数据库的值),集合的key值大小写敏感,用Map的key取值时要区分key的大小写。 (2)优缺点: resultType结果集列名/别名要与java属性名一样,但是resultMap不受限制,因为resultMap有column来规定。 由于SQL类型与Java中类型部分不匹配,resultMap可以通过typeHandler=""来匹配(如:SQL中的0和1来表示java中的false和true;Date类型的转换),但是resultType无能为力。
 
2、parameterMap和patameterType:
表示传入参数的对应关系,前者不推荐使用,只是mybatis为了适应以前的版本,
patameterType=传入的参数类型 提示:看到Map字眼的想到映射关系,看到Type字眼的想到类型。
 
3、#和$:
select * from film where film_name=#
select * from film where film_name=$ 相同点:都是用来作为占位符。 不同点:#在预编译的时候会被替换为?,而$在预编译的时候直接将变量的值替换进去,而且没有引号(如select * from film where film_name=afei,所以还要加上引号变成“$...”,即select * from film where film_name=’afei‘)才是正确的,故一般都是用前者,个别情况会使用后者:如需要进行排序,且排序字段为表的某个字段时可以使用$(如select * from film order by film_name,order by后面直接写字段不用写引号,所以选用$)。
 

以上是关于mybatis混淆概念的主要内容,如果未能解决你的问题,请参考以下文章

MyBatis-Plus相关概念

MyBatis-Plus相关概念

mybatis学习笔记(一) for 概念

Mybatis和mybatis-spring一级缓存

MyBatis概念性面试题整理汇总

MyBatis概念