MyBatis 入门
Mybatis是一个**持久层(DAO)**框架
Mybatis的作用
操作数据库的增删改查
Mybatis框架能够让我们以最少的代码就可以操作数据库。从而提高开发的效率
持久层的零实现 (不需要写实现类)
优点
没有任何第三方依赖,安装简单,只要两个jar文件+配置几个sql映射文件,易于使用
灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql基本上可以实现我们不使用数据访问框架可以实现的所有功能
解除sql与程序代码的耦合:通过提供DAL层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
提供映射标签,支持对象与数据库的orm字段关系映射
提供xml标签,支持编写动态sql
缺点
编写SQL语句时工作量很大,尤其是字段多、关联表多时
SQL语句依赖于数据库,导致数据库移植性差,不能更换数据库
框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改
二级缓存机制不佳
Mybatis配置流程图
配置步骤
–需求:插入数据到数据库(用于框架测试)
第一步:导入包(任何框架需要的事情)
第二步:创建总配置文件,文件名随便写
第三步:创建一个映射接口
第四步:创建一个映射文件
第五步:在总配置文件加载映射文件。
第六步:编写测试插入数据代码
关于POJO中int类型和Integer类型的使用选择
选择Integer类型
1.所有的sql使用的默认类型都是null,如果你把POJO中的映射属性类型写为基本类型,当查找不到记录的时候,返回null赋给基本类型就会出错 ;
2.包装类型都可以相应的转化为基本类型,如果你设置为基本类型比如int的话,它默认初始化为0,但0本身就代表着一种含义,如果为null的话,既好理解,也可以方便开发人员转化!而且很多xml配置中默认都是null。
映射文件
说明 | |
---|---|
id | 指向对应Mapper接口的方法 |
resultType | 查询结果对应的封装的返回类型 |
parameterType | sql语句中的参数类型 |
<!-- resultType : 无论是多行查询还是单行查询,返回的结果类型都是对应的JavaBean的类型 -->
<select id="selectAll" resultType="cn.laowang.mybatis.pojo.User">
select * from user
</select>