Java Mybatis框架Dao层的实现与映射文件以及核心配置文件详解分析

网友投稿 353 2022-09-19


Java Mybatis框架Dao层的实现与映射文件以及核心配置文件详解分析

目录Mybatis的Dao层实现传统开发方式代理开发方式MyBatis映射文件深入动态sql语句动态SQL之动态SQL之SQL片段抽取总结Mybatis核心配置文件深入typeHandlers标签plugins标签总结

Mybatis的Dao层实现

传统开发方式

1、编写UserDao接口

public interface UserMapper {

public List findAll() throws IOException;

}

2、编写UserDaoImpl实现

3、测试传统方式

代理开发方式

代理开发方式介绍

采用Mybatis的代理开发方式实现DAO层的开发,这种方式是我们后面进入企业的主流.

Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体同上边Dao接口实现类方法。

Mapper接口开发需要遵循以下规范:

①Mapper.xml文件中的namespace与mapper接口的全限定名相同

②Mapper接口方法名和Mapper.xml中定义的每个statement的id相同

③Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql的parameterType的类型相同4、④Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相

1、编写UserMapper接口

2、测试代理方式

MyBatis映射文件深入

动态sql语句

动态sql语句描述【官方文档】

动态SQL之

我们根据实体类的不同取值,使用不同的SQL语句来进行查询。比如在 id如果不为空时可以根据id查询,如果username不同空时还要加入用户名作为条件。这种情况在我们的多条件组合查询中经常会碰到。

select * from user

and id=#{id}

and username=#{username}

and password=#{password}

当查询条件id和username都存在时,测试代码如下

动态http://SQL之

循环执行sql的拼接操作,例如: SELECT * FROM USER WHERE id IN (1,2,5)。

#{id}

测试代码如下

foreach标签的属性含义如下:

标签用于遍历集合,它的属性:

①collection:代表要遍历的集合元素,注意编写时不要写#{}

②open:代表语句的开始部分

③close:代表结束部分

④item:代表遍历集合的每个元素,生成的变量名

⑤sperator:代表分隔符

SQL片段抽取

Sql中可将重复的sql提取出来,使用时用include引用即可,最终达到sql重用的目的

总结

MyBatis映射文件配置:

:插入

:修改

:删除

: where条件

: if判断

:循环

: sql片段抽取

Mybatis核心配置文件深入

typeHandlers标签

无论是MyBatis在预处理语句(PreparedStatement)中设置一个参数时,还是从结果集中取出一个值时,都会用类型处理器将获取的值以合适的方式转换成java类型。下表描述了一些默认的类型处理器(截取部分)。

可以重写类型处理器或创建你自己的类型处理器来处理不支持的或非标准的类型。具体做法为:实现org.apache.ibatis.type.TypeHandler接口,或继承一个很便利的类org.apache.ibatis.type.BaseTypeHandler,然后可以选择性地将它映射到一个JDBC类型。例如需求:一个Java中的Date数据类型,我想将之存到数据库的时候存成一个1970年至今的毫秒数,取出来时转换成java的Date,即java的Date与数据库的varchar毫秒值之间转换。

开发步骤:

①定义转换类继承类BaseTypeHandler

②覆盖4个未实现的方法,其中setNonNullarameter为java程序设置数据到数据库的回调方法,getNullableResult为查询时 mysql的字符串类型转换成java的Type类型的方法

③在MyBatis核心配置文件中进行注册

④测试转换是否正确

public class DateTypeHandler extends BaseTypeHandler {

//将java类型 转换成 数据库需要的类型

public void setNonNullParameter(PreparedStatement preparedStatement, int i, Date date, JdbcType jdbcType) throws SQLException {

long time = date.getTime();

preparedStatement.setLong(i,time);

}

//将数据库中类型 转换成java类型

//String参数 要转换的字段名称

//ResultSet 查询出的结果集

public Date getNullableResult(ResultSet resultSet, String s) throws SQLException {

//获得结果集中需要的数据(long) 转换成Date类型 返回

long aLong = resultSet.getLong(s);

Date date = new Date(aLong);

return date;

}

//将数据库中类型 转换成java类型

public Date getNullableResult(ResultSet resultSet, int i) throws SQLException {

long aLong = resultSet.getLong(i);

Date date = new Date(aLong);

return date;

}

//将数据库中类型 转换成java类型

public Date getNullableResult(FPQKBKtIevCallableStatement callableStatement, int i) throws SQLException {

long aLong = callableStatement.getLong(i);

Date date = new Date(aLong);

return date;

}

}

测试添加操作

数据库数据:

plugins标签

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

开发步骤:

①导入通用PageHelper的坐标

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

③测试分页数据获取

①导入通用PageHelper的坐标

com.github.pagehelper

pagehelper

3.7.5

com.github.jsqlparser

jsqlparser

0.9.1

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

③测试分页数据获取

获得分页相关的其他参数

//获得与分页相关参数

PageInfo pageInfo = new PageInfo(userList);

System.out.println("当前页:"+pageInfo.getPageNum());

System.out.println("每页显示条数:"+pageInfo.getPageSize());

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());

总结

MyBatis核心配置文件常用标签:

1、properties标签:该标签可以加载外部的properties文件

2、 typeAliases标签:设置类型别名

3、environments标签:数据源环境配置标签

4、typeHandlers标签:配置自定义类型处理器

5、plugins标签:配置MyBatis的插件


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:华为设备vlan配置命令(华为交换机配vlan命令)
下一篇:华为设备配置链路聚合(华为链路聚合配置实验)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~