mtbatis入门

Mybatis入门总结

1.mybatis的介绍

mybatis就是一个封装来jdbc的持久层框架,它和hibernate都属于ORM框架,但是具体的说,hibernate是一个完全的orm框架,

而mybatis是一个不完全的orm框架。

Mybatis让程序员只关注sql本身,而不需要去关注如连接的创建、statement的创建等操作。

Mybatis会将输入参数、输出结果进行映射。

下载mybatis

mybaits的代码由github.com管理,下载地址:[https://github.com/mybatis/mybatis-3/releases]

工程搭建

  • Mybatis的核心包和依赖包
  • MySQl的驱动包
  • Junit(非必须)

5.4.2创建全局配置文件

在config目录下,创建SqlMapConfig.xml文件,该名称不是固定不变的。

根据用户ID查询用户信息

  • 映射文件

在config目录下,创建User.xml(这种命名规范是由ibatis遗留下来)

在全局配置文件中加载映射文件

测试代码

2.全局配置文件

1.1概览

  • SqlMapConfig.xml的配置内容和顺序如下(顺序不能乱):
  • Properties(属性)
  • Settings(全局参数设置)
  • typeAliases(类型别名)
  • typeHandlers(类型处理器)
  • objectFactory(对象工厂)
  • plugins(插件)
  • environments(环境信息集合)

environment(单个环境信息)
transactionManager(事物)
dataSource(数据源)

  • mappers(映射器)

1.2Settings

mybatis全局配置参数,全局参数将会影响mybatis的运行行为。

详细参见“mybatis学习资料/mybatis-settings.xlsx”文件

3.mybatis与hibernate的区别及各自应用场景

Mybatis技术特点:

  • 1、通过直接编写SQL语句,可以直接对SQL进行性能的优化;
  • 2、学习门槛低,学习成本低。只要有SQL基础,就可以学习mybatis,而且很容易上手;
  • 3、由于直接编写SQL语句,所以灵活多变,代码维护性更好。
  • 4、不能支持数据库无关性,即数据库发生变更,要写多套代码进行支持,移植性不好。

Hibernate技术特点:

  • 1、标准的orm框架,程序员不需要编写SQL语句。
  • 2、具有良好的数据库无关性,即数据库发生变化的话,代码无需再次编写。
  • 3、学习门槛高,需要对数据关系模型有良好的基础,而且在设置OR映射的时候,需要考虑好性能和对象模型的权衡。
  • 4、程序员不能自主的去进行SQL性能优化。

Mybatis应用场景:

需求多变的互联网项目,例如电商项目。

Hibernate应用场景:

需求明确、业务固定的项目,例如OA项目、ERP项目等。