上次我们对mybatis的核心文件讲了一些标签,还有几个没用讲,这次我们就把剩下的讲了
typeHandlers标签(类型转换标签):有些类型他们是可以自动转换的,但是有些是不能自动转换的。这个标签的主要作用是当数据库的数据类型和java数据类型不一样的时候,我们就需要用到它。比如我们在数据库中,我们有生日字段,但是里面存的是1970年到现在的毫秒数,是一个长整型,但是在java的数据类型为日期类型。
开发步骤:
1,定义转换类继承类BaseTypeHandler
2,覆盖4个未实现的方法,其中setNonNullParameter为java程序设置数据到数据库的回调方法,getNullableResult为查询时mysql的字符串类型转换成java的Type类型的方法
3 在MyBatis核心配置文件中进行注册
4 测试转换是否正确
代码演示:
第一步:定义转换类继承类BaseTypeHandler
public class DateHandler extends BaseTypeHandler{ @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; } }
这里进行阐述一下,首先在类的那一行有一个
第二步:,覆盖4个未实现的方法,其中setNonNullParameter为java程序设置数据到数据库的回调方法,getNullableResult为查询时mysql的字符串类型转换成java的Type类型的方法
public class DateHandler extends BaseTypeHandler{ @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的坐标
com.github.pagehelper pagehelper3.7.5 com.github.jsqlparser jsqlparser0.9.1
第二步:在mybatis核心配置文件中配置PageHelper插件
这里面的属性需要配置(配置方言,不同的数据库不一样)
第三步:测试
@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 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 userList=mapper.findAll();
for (User user : userList) {
System.out.println(user);
}
// 获得与分页相关的参数
PageInfo pageInfo=new PageInfo(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
PageInfopageInfo=new PageInfo (userList);
里面的泛型填的是其实体类,后面括号填结果集。



