mybatis核心文件的深入了解

上次我们对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);

里面的泛型填的是其实体类,后面括号填结果集。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值