上次我们对mybatis的核心文件讲了一些标签,还有几个没用讲,这次我们就把剩下的讲了
typeHandlers标签(类型转换标签):有些类型他们是可以自动转换的,但是有些是不能自动转换的。这个标签的主要作用是当数据库的数据类型和java数据类型不一样的时候,我们就需要用到它。比如我们在数据库中,我们有生日字段,但是里面存的是1970年到现在的毫秒数,是一个长整型,但是在java的数据类型为日期类型。
开发步骤:
1,定义转换类继承类BaseTypeHandler<T>
2,覆盖4个未实现的方法,其中setNonNullParameter为java程序设置数据到数据库的回调方法,getNullableResult为查询时mysql的字符串类型转换成java的Type类型的方法
3 在MyBatis核心配置文件中进行注册
4 测试转换是否正确
代码演示:
第一步:定义转换类继承类BaseTypeHandler<T>
public class DateHandler extends BaseTypeHandler<Date> {
@Override
//负责将java类型转换为数据库类型
public void setNonNullParameter(PreparedStatement preparedStatement, int i, Date date, JdbcType jdbcType) throws SQLException {
}
@Override
//将数据库中类型转换为java的数据类型
public Date getNullableResult(ResultSet resultSet, String s) throws SQLException {
return null;
}
@Override
//将数据库中类型转换为java的数据类型
public Date getNullableResult(ResultSet resultSet, int i) throws SQLException {
return null;
}
@Override
//将数据库中类型转换为java的数据类型
public Date getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
return null;
}
}
这里进行阐述一下,首先在类的那一行有一个<Date>表示转换的类型是date类型的。然后下面的方法。第一个是java转换为数据库类型,后面的三个都是数据库类型转换为java类型(因为数据库底层可能调用不同的几个方法)
第二步:,覆盖4个未实现的方法,其中setNonNullParameter为java程序设置数据到数据库的回调方法,getNullableResult为查询时mysql的字符串类型转换成java的Type类型的方法
public class DateHandler extends BaseTypeHandler<Date> {
@Override
//负责将java类型转换为数据库类型
public void setNonNullParameter(PreparedStatement preparedStatement, int i, Date date, JdbcType jdbcType) throws SQLException {
long time = date.getTime();
preparedStatement.setLong(i,time);
}
@Override
//将数据库中类型转换为java的数据类型
//String 是我数据库要转换的字段名称
//ResultSet,是查询出的结果集
public Date getNullableResult(ResultSet resultSet, String s) throws SQLException {
//获得结果集中需要数据转换成Date类型的
long aLong = resultSet.getLong(s);
Date date=new Date(aLong);
return date;
}
@Override
//将数据库中类型转换为java的数据类型
public Date getNullableResult(ResultSet resultSet, int i) throws SQLException {
long aLong = resultSet.getLong(i);
Date date=new Date(aLong);
return date;
}
@Override
//将数据库中类型转换为java的数据类型
public Date getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
long aLong = callableStatement.getLong(i);
Date date=new Date(aLong);
return date;
}
}
阐述一下:四个方法的第一个参数都是可以帮我们执行的一个对象。然后参数i,代表的是数据库字段的序号,参数s代表的是数据库字段名。
第三步:在MyBatis核心配置文件中进行注册
第四步:进行测试:
数据库类型向java类型的转换:
@Test
//数据库中的类型转换成java类型
public void test2() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user= mapper.findById(6);
System.out.println("user中的birthday"+user.getBirthday());
sqlSession.commit();
sqlSession.close();
}
测试效果:
关于plugins标签:(插件标签用来拓展功能的)例如分页助手PageHelper
开发步骤:
1 导入通用PageHelper的坐标
pagehelper
还有jsqlparser
2 在mybatis核心配置文件中配置PageHelper插件
3 测试分页数据获取
代码实例:
第一步:导入通用PageHelper的坐标
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>3.7.5</version>
</dependency>
<dependency>
<groupId>com.github.jsqlparser</groupId>
<artifactId>jsqlparser</artifactId>
<version>0.9.1</version>
</dependency>
第二步:在mybatis核心配置文件中配置PageHelper插件
<!-- 配置分页助手插件-->
<plugins>
<plugin interceptor="com.github.pagehelper.PageHelper">
<property name="dialect" value="mysql"/>
</plugin>
</plugins>
这里面的属性需要配置(配置方言,不同的数据库不一样)
第三步:测试
@Test
//查询全部
public void test3() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
//设置分页的参数 当前页和每条显示的条数
PageHelper.startPage(2,2);
List<User> userList=mapper.findAll();
for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}
效果:
他里面还有很多的方法:
@Test
//查询全部
public void test3() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
//设置分页的参数 当前页和每条显示的条数
PageHelper.startPage(2,2);
List<User> userList=mapper.findAll();
for (User user : userList) {
System.out.println(user);
}
// 获得与分页相关的参数
PageInfo<User> pageInfo=new PageInfo<User>(userList);
System.out.println("当前页:"+pageInfo.getPageNum());
System.out.println("每页显示的条数:"+pageInfo.getSize());
System.out.println("总条数:"+pageInfo.getTotal());
System.out.println("总页数:"+pageInfo.getPages());
System.out.println("上一页:"+pageInfo.getPrePage());
System.out.println("下一页:"+pageInfo.getNextPage());
System.out.println("是否是第一页:"+pageInfo.isIsFirstPage());
System.out.println("是否是最后一页:"+pageInfo.isIsLastPage());
sqlSession.close();
}
效果:
获取分页信息,需要我们创建新的对象PageInfo
PageInfo<User> pageInfo=new PageInfo<User>(userList);
里面的泛型填的是其实体类,后面括号填结果集。