黑马程序员技术交流社区

标题: 成都校区 [打印本页]

作者: 呜呜啦哦    时间: 2019-6-12 14:02
标题: 成都校区
MyBatis核心配置文件深入

3.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核心配置文件中进行注册

测试转换是否正确

    public class MyDateTypeHandler extends BaseTypeHandler<Date> {
        public void setNonNullParameter(PreparedStatement preparedStatement, int i, Date date, JdbcType type) {
            preparedStatement.setString(i,date.getTime()+"");
        }
        public Date getNullableResult(ResultSet resultSet, String s) throws SQLException {
            return new Date(resultSet.getLong(s));
        }
        public Date getNullableResult(ResultSet resultSet, int i) throws SQLException {
            return new Date(resultSet.getLong(i));
        }
        public Date getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
            return callableStatement.getDate(i);
        }
    }



    <!--注册类型自定义转换器-->
    <typeHandlers>
        <typeHandler handler="com.itheima.typeHandlers.MyDateTypeHandler"></typeHandler>
    </typeHandlers>

测试添加操作:

    user.setBirthday(new Date());
    userMapper.add2(user);

数据库数据:



测试查询操作:

   



3.2 plugins标签

MyBatis可以使用第三方的插件来对功能进行扩展,分页助手PageHelper是将分页的复杂操作进行封装,使用简单的方式即可获得分页的相关数据

开发步骤:

①导入通用PageHelper的坐标

②在mybatis核心配置文件中配置PageHelper插件

③测试分页数据获取





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2