2.0 基础篇

2017-11-30 22:22:02 6,191 2

mybatis基础篇主要用于讲解mybatis的基本使用,以及mybatis如何与spring进行整合,要求读者有jdbc编程基础。关于mybatis和mybatis-spring的基本使用,读者也可以直接参考官方文档,官方文档的问题在于,介绍比较详细,但是缺乏demo案例,同时没有介绍不同版本之间的差异: 

      mybatis官方中文网址:http://www.mybatis.org/mybatis-3/zh/index.html

      mybatis-spring官方中文网址:http://www.mybatis.org/spring/zh/

1 什么orm框架

所谓orm指的是对象关系映射(Object Relational Mapping)。其中Object指的就是java中的对象,Relational指的是关系型数据,而Mapping指的就是对象与关系型数据库的映射。 其中映射是关键。

所谓映射,就是针对关系型数据库中的表,我们要创建与之对应的java对象,例如:有一个user表,定义如下:

CREATE TABLE  user(
  id int,
  name VARCHAR(255) not NULL ,
  age int ,
  PRIMARY KEY (id)
)ENGINE =INNODB DEFAULT CHARSET=utf8;

  针对这个表,我们要创建一个与之对应的Java对象User  

package com.tianshouzhi.mybatis.quickstart;
public class User {
     private int id;
     private String name;
     private int age;
     public int getId() {
         return id;
     }
     public void setId(int id) {
         this.id = id;
     }
     public String getName() {
         return name;
     }
     public void setName(String name) {
         this.name = name;
     }
     public int getAge() {
         return age;
     }
     public void setAge(int age) {
         this.age = age;
     }
}

可以看到User对象中的属性名与数据库表user的字段名是一一对应的。不过即使名字不一样也没有关系,因为ORM框架通常都会支持用户定义映射文件(Mapping File)来指定java对象中的属性与数据库表字段的对应关系。

有了这个映射关系,ORM框架既可以发挥它的威力,例如:

  • 保存记录:直接保存java对象即可,ORM框架会自动将java对象每个属性的值保存到对应的数据库表对应的字段上。

  • 查询记录:ORM框架会将查询到的结果集(ResultSet)封装成对应的Java对象。

...

这些所有强大的功能都是在对象关系映射的基础上完成的。

2 mybatis与其他orm框架的对比

 ORM框架有很多,除了Mybatis,比较著名的还有Hibernate、Toplink等。通常我们把Mybatis称之为半自动的ORM框架,把Hibernate、TopLink等称之为全自动的ORM框架。

  • 所谓全自动:像Hibernate这种ORM框架,开发人员只需要定义好映射关系,连sql都不用写了,ORM框架会动态的生成sql去操作数据库。因此我们在程序中,对于数据库的CRUD,操作的都是Java对象。

  • 所谓半自动:指的是Mybatis中,虽然CRUD操作也是操作的Java对象,但是对应的sql还是需要开发人员自己来写,没有实现全自动的根据映射关系自动生成sql的功能。

    从代码简洁性上来说,肯定是全自动的ORM框架更好。

      但是从效率来说:半自动的ORM框架比全自动的ORM框架要更好。举个例子,Hibernate查询一条记录时,会将表中的所有字段查询出来,封装到Java对象中。这是因为hibernate中sql是动态生成的,不知道开发人员想要查询哪几个字段,因此只要查出所有。而Mybatis这种半自动ORM框架需要自己写SQL,因此我们可以指定只查询哪几个数据库字段。

      从灵活性上来说:肯定是Mybatis更灵活,还是因为Sql由开发人员自己控制。Hibernate也可以自己写SQL来指定需要查询的字段,但这样就破坏了Hibernate开发的简洁性。

     从上手难易程度来说:Hibernate比Mybatis更加复杂。因为全自动的orm框架比半自动的ORM框架抽象程度更高,理解起来也更为复杂。

     目前,国内的大型互联网公司使用的基本上都是mybatis。从笔者的工作经历来说也是这样,经历的几家公司(电信、平安、阿里、新美大),所在的项目组,使用的都是mybatis。因此对于初学者来说,学习mybatis可能比学习其他的orm框架在国内更加实用。

3 mybatis与mybatis-spring的关系       

可以用下图来进行说明:

Image.png

我们可以单独使用mybatis,只有在和spring整合的时候,才需要使用mybatis-spring。

 mybatis在操作数据库时,需要依赖数据源(DataSource),mybatis自带了几个数据源实现,我们也可以自己指定其他实现,如druid、c3p0,dbcp等。


上一篇:1.0 教程简介 下一篇:2.1 mybatis快速入门