栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

mybatis核心文件的深入了解

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

mybatis核心文件的深入了解

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

这里进行阐述一下,首先在类的那一行有一个表示转换的类型是date类型的。然后下面的方法。第一个是java转换为数据库类型,后面的三个都是数据库类型转换为java类型(因为数据库底层可能调用不同的几个方法)

第二步:,覆盖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
      pagehelper
      3.7.5
    
    
      com.github.jsqlparser
      jsqlparser
      0.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

PageInfo pageInfo=new PageInfo(userList);

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

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/885717.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号