MyBatis(1)——快速入门

MyBatis 简介

MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis,是一个基于Java的持久层框架。

持久层:可以将业务数据存储到磁盘,具备长期存储能力,只要磁盘不损坏,在断电或者其他情况下,重新开启系统仍然可以读取到这些数据。

优点:可以使用巨大的磁盘空间存储相当量的数据,并且很廉价

缺点:慢(相对于内存而言)

为什么使用 MyBatis

在我们传统的 JDBC 中,我们除了需要自己提供 SQL 外,还必须操作 Connection、Statment、ResultSet,不仅如此,为了访问不同的表,不同字段的数据,我们需要些很多雷同模板化的代码,闲的繁琐又枯燥

而我们在使用了MyBatis之后,只需要提供 SQL 语句就好了,其余的诸如:建立连接、操作 Statment、ResultSet,处理 JDBC 相关异常等等都可以交给 MyBatis 去处理,我们的关注点于是可以就此集中在 SQL 语句上,关注在增删改查这些操作层面上。

并且 MyBatis 支持使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

搭建 MyBatis 环境

首先,我们需要先下载和搭建 MyBatis 的开发环境。

下载 MyBatis 工程包

下载好 MyBatis 的包解压后,可以得到以下的文件目录:

为 IDEA 配置 MyBatis 环境

IDEA 默认是不支持 MyBatis 开发的,需要自己下载第三方插件来支持,可惜的是功能强大的【MyBatis Plugin】是收费的,需要我们自己破解!

第一步:在 IDEA 中下载 MyBatis Plugin

在【File】菜单下找到【Settings】,然后再【Plugins】下点击【Browse repositories..】:

在搜索栏中输入【MyBatis Plugin】,然后点击【Install】(我这里是安装好了所以没有这个按钮):

第二步:破解

把它下载到 【D:\Download\】目录下,打开 idea.vmoptions (【Help】 【Eidt Custom VM Options…】):

在下方插入

重启 IDEA,首次启动需要信任本地服务器 ssl 证书,点击接受后如未激活,再次重启即可:

至此,我们就为 IDEA 配置好了 MyBatis 的开发环境,可以检验一下是否安装成功:

第一个 MyBatis 程序

我们来实际开发一个 MyBatis 程序,感受一下。

第一步:准备数据库

首先我们创建一个数据库【mybatis】,编码方式设置为 UTF-8,然后再创建一个名为【student】的表,插入几行数据:

第二步:创建工程

在 IDEA 中新建一个 Java 工程,并命名为【HelloMybatis】,然后导入必要的 jar 包:

mybatis-3.4.6.jar

mysql-connector-java-5.1.21-bin.jar

第三步:创建实体类

在 Package【pojo】下新建实体类【Student】,用于映射表 student:

第四步:配置文件 mybatis-config.xml

在【src】目录下创建 MyBaits 的主配置文件 ,其主要作用是提供连接数据库用的驱动,数据名称,编码方式,账号密码等,我们在后面说明:

第五步:配置文件 Student.xml

在 Package【pojo】下新建一个【Student.xml】文件:

由于上面配置了 别名,所以在这里的 可以直接写 Student,而不用写类的全限定名 pojo.Student

属性其实就是对 SQL 进行分类管理,实现不同业务的 SQL 隔离

SQL 语句的增删改查对应的标签有:

第六步:编写测试类

在 Package【test】小创建测试类【TestMyBatis】:

运行测试类:

基本原理

应用程序找 MyBatis 要数据

MyBatis 从数据库中找来数据

1.通过 mybatis-config.xml 定位哪个数据库

2.通过 Student.xml 执行对应的 sql 语句

3.基于 Student.xml 把返回的数据库封装在 Student 对象中

4.把多个 Student 对象装载一个 Student 集合中

返回一个 Student 集合

参考资料:How2j.cn-MyBatis 相关教程——http://how2j.cn/k/mybatis/mybatis-tutorial/1087.html#nowhere

CRUD 操作

我们来看看常规的一套增删改查应该怎么实现:

第一步:配置 Student.xml

首先,我们在 SQL 映射文件中新增语句,用来支撑 CRUD 的系列操作

parameterType:要求输入参数的类型

resultType:输出的类型

第二步:实现增删改查

上述的程序中:

通过 增加了一个 ID 和 studentID 都为 4,名字为“新增加的学生” 的学生

通过 删除了 ID = 1 的学生

通过 获取了 ID = 2的学生

通过 将 ID = 2 的学生的名字修改为 “修改的学生”

通过 来提交事务,也可以简单理解为更新到数据库

运行获得正确结果:

模糊查询

如果要对数据库中的 student 表进行模糊查询,需要通过匹配名字中的某个字来查询该用户。

我们首先在 Student.xml 配置文件中配置 SQL 映射:

注意:标签对中 SQL 语句的 “${}” 符号,表示拼接 SQL 串,将接受的参数内容不加任何修饰地拼接在 SQL 中,在 “${}” 中只能使用 来代表其中的参数。

因为是模糊查询,所以得到的查询结果可能不止一个,所以我们使用 SqlSession 的 selectList() 方法,写一个测试方法:

测试结果:

总结一下

关于 parameterType:就是用来在 SQL 映射文件中指定输入参数类型的,可以指定为基本数据类型(如 int、float 等)、包装数据类型(如 String、Interger 等)以及用户自己编写的 JavaBean 封装类

关于 resultType:在加载 SQL 配置,并绑定指定输入参数和运行 SQL 之后,会得到数据库返回的响应结果,此时使用 resultType 就是用来指定数据库返回的信息对应的 Java 的数据类型。

关于 “#{}” :在传统的 JDBC 的编程中,占位符用 “?” 来表示,然后再加载 SQL 之前按照 “?” 的位置设置参数。而 “#{}” 在 MyBatis 中也代表一种占位符,该符号接受输入参数,在大括号中编写参数名称来接受对应参数。当 “#{}” 接受简单类型时可以用 或者其他任意名称来获取。

关于 “${}” :在 SQL 配置中,有时候需要拼接 SQL 语句(例如模糊查询时),用 “#{}” 是无法达到目的的。在 MyBatis 中,“${}” 代表一个 “拼接符号” ,可以在原有 SQL 语句上拼接新的符合 SQL 语法的语句。使用 “${}” 拼接符号拼接 SQL ,会引起 SQL 注入,所以一般不建议使用 “${}”。

MyBatis 使用场景:通过上面的入门程序,不难看出在进行 MyBatis 开发时,我们的大部分精力都放在了 SQL 映射文件上。MyBatis 的特点就是以 SQL 语句为核心的不完全的 ORM(关系型映射)框架。与 Hibernate 相比,Hibernate 的学习成本比较高,而 SQL 语句并不需要开发人员完成,只需要调用相关 API 即可。这对于开发效率是一个优势,但是缺点是没办法对 SQL 语句进行优化和修改。而 MyBatis 虽然需要开发人员自己配置 SQL 语句,MyBatis 来实现映射关系,但是这样的项目可以适应经常变化的项目需求。所以使用 MyBatis 的场景是:对 SQL 优化要求比较高,或是项目需求或业务经常变动。

参考资料:

《Java EE 互联网轻量级框架整合开发》

《Spring MVC + MyBatis开发从入门到项目实战》

How2j-MyBatis 系列教程——http://how2j.cn/k/mybatis/mybatis-tutorial/1087.html

全能的百度和万能的大脑

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180612G0OHDU00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券