mybatis快速入门学习教程新手注意问题小结
什么是mybatis
mybatis是支持普通sql查询,存储过程和高级映射的优秀持久层框架。mybatis消除了几乎所有的jdbc代码和参数的手工设置以及结果集的检索。mybatis使用简单的xml或注解用于配置和原始映射,将接口和java的pojos(plan old java objects,普通的java对象)映射成数据库中的记录.
orm工具的基本思想
无论是用过的hibernate,mybatis,你都可以法相他们有一个共同点:
1. 从配置文件(通常是xml配置文件中)得到 sessionfactory.
2. 由sessionfactory 产生 session
3. 在session 中完成对数据的增删改查和事务提交等.
4. 在用完之后关闭session 。
5. 在java 对象和 数据库之间有做mapping 的配置文件,也通常是xml 文件。
参数问题
在映射文件中通过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快速入门学习教程新手注意问题小结,希望对大家有所帮助