mybatis快速入门学习教程新手注意问题小结
作者:精品唯居 时间:2023-08-23 18:52:38
什么是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快速入门学习教程新手注意问题小结网站的支持!
来源:http://www.cnblogs.com/liyasong/archive/2017/02/10/6387004.html
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
使用Deflate算法对文件进行压缩与解压缩的方法详解
C#中WPF颜色对话框控件的实现
![](https://img.aspxhome.com/file/2023/7/88437_0s.png)
Spring SpringMVC在启动完成后执行方法源码解析
Springboot启动后立即某个执行方法的四种方式
SpringMVC数据页响应ModelAndView实现页面跳转
![](https://img.aspxhome.com/file/2023/6/92646_0s.jpg)
Java负载均衡算法实现之轮询和加权轮询
Java 使用poi把数据库中数据导入Excel的解决方法
![](https://img.aspxhome.com/file/2023/0/62840_0s.png)
android Retrofit2+okHttp3使用总结
Maven继承与聚合详解及作用介绍
![](https://img.aspxhome.com/file/2023/4/66184_0s.png)
mybatis group by substr函数传参报错的解决
深入理解C#窗体关闭事件
![](https://img.aspxhome.com/file/2023/7/122637_0s.jpg)
MyBatis快速入门
![](https://img.aspxhome.com/file/2023/5/62155_0s.png)
SpringBoot使用Mybatis&Mybatis-plus文件映射配置方法
Java简单实现SpringMVC+MyBatis分页插件
Springboot使用@RefreshScope注解实现配置文件的动态加载
![](https://img.aspxhome.com/file/2023/9/69909_0s.jpg)
Java常用锁synchronized和ReentrantLock的区别
![](https://img.aspxhome.com/file/2023/3/116803_0s.webp)
Spring boot整合mybatis实现过程图解
![](https://img.aspxhome.com/file/2023/0/78880_0s.png)
举例讲解Java编程中this关键字与super关键字的用法
Android Activity的启动过程源码解析
![](https://img.aspxhome.com/file/2023/4/138514_0s.png)