1.MyBatis核心配置文件
1.1typeHandlers标签
无论是 MyBatis 在预处理语句(PreparedStatement)中设置一个参数时,还是从结果集中取出一个值时, 都会用
类型处理器将获取的值以合适的方式转换成 Java 类型。下表描述了一些默认的类型处理器(截取部分)
你可以重写类型处理器或创建你自己的类型处理器来处理不支持的或非标准的类型。具体做法为:实现 org.apache.ibatis.type.TypeHandler 接口, 或继承一个很便利org.apache.ibatis.type.BaseTypeHandler, 然 后可以选择性地将它映射到一个JDBC类型。例如需求:一个Java中的Date数据类型,我想将之存到数据库的时候存成一 个1970年至今的毫秒数,取出来时转换成java的Date,即java的Date与数据库的varchar毫秒值之间转换。
开发步骤:
① 定义转换类继承类BaseTypeHandler<T>
② 覆盖4个未实现的方法,其中setNonNullParameter为java程序设置数据到数据库的回调方法,getNullableResult
为查询时 mysql的字符串类型转换成 java的Type类型的方法
③ 在MyBatis核心配置文件中进行注册
④ 测试转换是否正确
package com.lin.handler;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Date;
public class DateHandler extends BaseTypeHandler<Date> {
//将java类型转换为数据库需要的类型
@Override
public void setNonNullParameter(PreparedStatement preparedStatement, int i, Date date, JdbcType jdbcType) throws SQLException {
long time = date.getTime();
preparedStatement.setLong(i,time);
}
//将数据库类型转化为java类型
//String参数 要转换字段的名称
//resultSet 查询出来的结果集
@Override
public Date getNullableResult(ResultSet resultSet, String s) throws SQLException {
//获得结果集中需要的数据Long 转换成Date类型
long aLong = resultSet.getLong(s);
Date date = new Date(aLong);
return date;
}
@Override
public Date getNullableResult(ResultSet resultSet, int i) throws SQLException {
long aLong = resultSet.getLong(i);
Date date = new Date(aLong);
return date;
}
@Override
public Date getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
long aLong = callableStatement.getLong(i);
Date date = new Date(aLong);
return date;
}
}
告诉mybatis
<!--注册类型处理器-->
<typeHandlers >
<typeHandler handler="com.lin.handler.DateHandler"></typeHandler>
</typeHandlers>
测试添加操作
User user = new User(); user.setUsername("sda"); user.setPassword("46456"); user.setBirthday(new Date());
数据库表
1.2 plugins标签
MyBatis可以使用第三方的插件来对功能进行扩展,分页助手PageHelper是将分页的复杂操作进行封装,使用简单的方式即
可获得分页的相关数据
开发步骤:
① 导入通用PageHelper的坐标
② 在mybatis核心配置文件中配置PageHelper插件
③ 测试分页数据获取
(1)导入PageHelper坐标
<!--分页查询相关坐标-->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.3.2</version>
</dependency>
<dependency>
<groupId>com.github.jsqlparser</groupId>
<artifactId>jsqlparser</artifactId>
<version>4.6</version>
</dependency>
(2)在mybatis核心配置文件中配置PageHelper插件
<!--配置分页插件助手--> <plugins> <plugin interceptor="com.github.pagehelper.PageInterceptor"></plugin> </plugins>
注意:据说这个pagehelper插件4.0以下的版本,基本不支持多边查询的分页,并且!!PageHelper插件4.0.0以后的版本支持自动识别使用的数据库,所以我们就不必再指定方言!!!这是其一,其次呢,我们不能使用pagehelper,改为PageInterceptor,PageHelper5.0版本pagehelper是继承了PageMethod和实现了Dialect,PageInterceptor是实现了Interceptor接口
(3)测试分页代码
//设置分页相关参数 当前页+每页条数 PageHelper.startPage(1,4); List<User> userList = mapper.findAll(); for (User user : userList) { System.out.println(user); }
获得分页相关的参数
//获取与分页相关的参数 PageInfo<User> userPageInfo = new PageInfo<>(userList); System.out.println("当前页:"+userPageInfo.getPageNum()); System.out.println("上一页:"+userPageInfo.getPrePage()); System.out.println("总条数:"+userPageInfo.getTotal()); System.out.println("总页数:"+userPageInfo.getPages()); System.out.println("是否是第一页"+userPageInfo.isIsFirstPage()); System.out.println("是否是最后一页:"+userPageInfo.isIsLastPage());
1.3总结
MyBatis核心配置文件常用标签
1.properties标签:该标签可以加载外部的properties文件
2.typeAliases标签:设置类的别名
3.environments标签:数据源环境配置标签
4.typeHandlers标签:配置自定义类型处理器
5.plugins标签:配置mybatis插件