Mybatis的学习与理解
Mybatis
1.介绍
Mybatis是支持SQL查询,存储和映射的持久层框架。使用时消除了JDBC代码和参数的设置以及对结果集的封装
Mybatis可以使用注解来进行配置和进行映射,将Mapper和Pojo映射为数据库中的记录
2.Mybatis优势
- 消除了JDBC的打码冗余
- 简单易学,可以与数据库协同工作
- 简单的接收SQL语句
- 可以提供第三方缓存的集成支持
- 性能更好
3.Mybatis基本使用步骤
1.加入Maven依赖
点击查看代码
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.1</version>
</dependency>
- 创建Mapper文件
- 也叫做映射文件,分别为XXXMapper.java和XXXMapper.xml
- XXXMapper.java文件中存放的是方法名称
>
3.XXXMapper.xml 里面存放的是Sql语句
4.创建Mybatis-config.xml配置文件,在resources中
1. 连接数据库
2. 指定mapper文件的内容
Mybatis动态代理
- 理解动态代理
-
- Mybatis帮忙创建dao(mapper)接口的实现类,在实现类中调用SqlSession的方法执行sql语句。
- 使用动态代理的要求
- dao接口和mapper文件放在一起
- dao和mapper文件名称一致
- mapper文件中的namespace的值是dao接口的全限定名称
- mapper文件中的select、delete、update等的id是接口中的方法名称
- dao接口中不适用重载方法
理解参数
- 一个简单类型的参数#
- 多个简单类型的参数,使用@Param("自定义名称")
- 使用一个java对象,对象的属性值作为mapper文件找到的参数,#
- 使用参数位置:语法:#{arg0},#{arg1} ,mybatis3.4之前使用的是 #{0},#
- 使用map作为参数,#
#和$的区别
- (#)是占位符,表示列值,放在等号的右侧
- ($)是占位符,表示字符串连接,sql连接成一个字符串
- (#)占位符使用的jdbc指定PerparedStatement对象执行sql语句效率高,没有sql语句注入的风险
- $使用的是Statement对象执行sql,效率低,有sql注入的风险
Mybatis返回结果
- resultType:表示sql语句的执行结果转化为java对象的类型
- 类型的全限定名称
- 定义别名:1.mybatis主配置文件中定义;2.
;3.使用注解@Alias - resultMap:自定义类名和java对象属性名的关系
- like:1.在java代码中指定like的内容;2.在mapper中拼接like

>

浙公网安备 33010602011771号