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后面直接写字段不用写引号,所以选用${})。
 

猜你喜欢

转载自www.cnblogs.com/afei1759/p/11257226.html