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

mybatis快速入门学习教程新手注意问题小结

在我们通过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

标签:mybatis,入门
0
投稿

猜你喜欢

  • 使用Deflate算法对文件进行压缩与解压缩的方法详解

    2022-01-27 09:48:49
  • C#中WPF颜色对话框控件的实现

    2023-04-13 06:09:41
  • Spring SpringMVC在启动完成后执行方法源码解析

    2023-01-01 12:46:57
  • Springboot启动后立即某个执行方法的四种方式

    2022-12-29 16:35:52
  • SpringMVC数据页响应ModelAndView实现页面跳转

    2022-04-29 15:21:10
  • Java负载均衡算法实现之轮询和加权轮询

    2023-07-16 15:27:17
  • Java 使用poi把数据库中数据导入Excel的解决方法

    2022-09-19 14:18:52
  • android Retrofit2+okHttp3使用总结

    2023-07-31 21:02:10
  • Maven继承与聚合详解及作用介绍

    2023-03-08 00:14:36
  • mybatis group by substr函数传参报错的解决

    2022-09-10 03:44:34
  • 深入理解C#窗体关闭事件

    2023-06-01 14:38:56
  • MyBatis快速入门

    2023-11-13 06:45:14
  • SpringBoot使用Mybatis&Mybatis-plus文件映射配置方法

    2023-05-16 12:53:02
  • Java简单实现SpringMVC+MyBatis分页插件

    2023-09-09 23:08:45
  • Springboot使用@RefreshScope注解实现配置文件的动态加载

    2022-06-11 10:06:00
  • Java常用锁synchronized和ReentrantLock的区别

    2023-06-01 04:42:21
  • Spring boot整合mybatis实现过程图解

    2023-01-15 09:31:05
  • 举例讲解Java编程中this关键字与super关键字的用法

    2023-03-09 01:46:02
  • Android Activity的启动过程源码解析

    2023-12-25 11:16:00
  • 关于maven使用过程中无法导入依赖的一些总结

    2021-12-16 01:51:20
  • asp之家 软件编程 m.aspxhome.com