mybatis入门-新手注意问题

Posted 精品唯居

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis入门-新手注意问题相关的知识,希望对你有一定的参考价值。

  参数问题

    在映射文件中通过parameterType指定输入参数的类型;在映射文件中通过resultType指定输出结果的类型。

  占位符和拼接符问题

    #{}表示一个占位符号,#{}接收输入参数,类型可以是简单类型,pojo、hashmap。

    如果接收简单类型,#{}中可以写成value或其它名称。

    #{}接收pojo对象值,通过OGNL读取对象中的属性值,通过属性.属性.属性...的方式获取对象属性值。

     

    ${}表示一个拼接符号,会引用sql注入,所以不建议使用${}。

    ${}接收输入参数,类型可以是简单类型,pojo、hashmap。

    如果接收简单类型,${}中只能写成value。

    ${}接收pojo对象值,通过OGNL读取对象中的属性值,通过属性.属性.属性...的方式获取对象属性值。

  selectone和selectList

    

    在我们通过sqlSession进行查询的时候,可以选择selectOne和选择SelectList,这个时候,它们是有区别的。

    selectOne表示查询出一条记录进行映射。如果使用selectOne可以实现使用selectList也可以实现(list中只有一个对象)。

    selectList表示查询出一个列表(多条记录)进行映射。如果使用selectList查询多条记录,不能使用selectOne。

    如果使用selectOne报错:

    org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned by selectOne(), but found: 4

以上是关于mybatis入门-新手注意问题的主要内容,如果未能解决你的问题,请参考以下文章

mybatis新手入门常见问题集(持续更新)

MyBatis 入门

mybatis复习

MyBatis 快速入门

SpringBoot整合mybatis快速入门

Mybatis从入门到精通系列 12——Mybatis 的一级缓存与二级缓存