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 工程包

打开链接 http://github.com/mybatis/mybatis-3/releases 下载 MyBatis 所需要的包和源码,当前最新版本为 3.4.6,官方还提供了文档: 戳这里,虽然感觉写得一般,但还是有一些参考价值…唉,别当教程看,当字典看!


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


其中 mybatis-3.4.6.jar 包就是 MyBatis 的项目工程包,【lib】文件夹下就是 MyBatis 项目需要依赖的第三方包,pdf 文件是它英文版的说明,不要英文也可以戳上面的链接。

为 IDEA 配置 MyBatis 环境

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

第一步:在 IDEA 中下载 MyBatis Plugin

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


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

第二步:破解
最新支持破解的版本号为:v3.58 crack,下载链接:https://github.com/mrshawnho/ideaagent/releases


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

在下方插入 -javaagent:D:/Download/ideaagent-1.2.jar


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


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


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

第一步:准备数据库

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

DROP DATABASE IF EXISTS mybatis;
CREATE DATABASE mybatis DEFAULT CHARACTER SET utf8;use mybatis;
CREATE TABLE student(id int(11) NOT NULL AUTO_INCREMENT,studentID int(11) NOT NULL UNIQUE,name varchar(255) NOT NULL,PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;INSERT INTO student VALUES(1,1,'我没有三颗心脏');
INSERT INTO student VALUES(2,2,'我没有三颗心脏');
INSERT INTO student VALUES(3,3,'我没有三颗心脏');

第二步:创建工程

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

mybatis-3.4.6.jar

mysql-connector-java-5.1.21-bin.jar

第三步:创建实体类

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

package pojo;public class Student {int id;int studentID;String name;/* getter and setter */
}

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

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

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!-- 别名 --><typeAliases><package name="pojo"/></typeAliases><!-- 数据库环境 --><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=UTF-8"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><!-- 映射文件 --><mappers><mapper resource="pojo/Student.xml"/></mappers></configuration>

第五步:配置文件 Student.xml

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

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="pojo"><select id="listStudent" resultType="Student">select * from  student</select>
</mapper>

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

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

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

第六步:编写测试类

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

package test;import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import pojo.Student;import java.io.IOException;
import java.io.InputStream;
import java.util.List;public class TestMyBatis {public static void main(String[] args) throws IOException {// 根据 mybatis-config.xml 配置的信息得到 sqlSessionFactoryString resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 然后根据 sqlSessionFactory 得到 sessionSqlSession session = sqlSessionFactory.openSession();// 最后通过 session 的 selectList() 方法调用 sql 语句 listStudentList<Student> listStudent = session.selectList("listStudent");for (Student student : listStudent) {System.out.println("ID:" + student.getId() + ",NAME:" + student.getName());}}
}

运行测试类:

基本原理

一.应用程序找 MyBatis 要数据

二.MyBatis 从数据库中找来数据

1.通过 mybatis-config.xml 定位哪个数据库
2.通过 Student.xml 执行对应的 sql 语句
3.基于 Student.xml 把返回的数据库封装在 Student 对象中
4.把多个 Student 对象装载一个 Student 集合中

三.返回一个 Student 集合


参考资料:https://how2j.cn/k/mybatis/mybatis-tutorial/1087.html#nowhere

CRUD 操作

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

第一步:配置 Student.xml
首先,我们在 SQL 映射文件中新增语句,用来支撑 CRUD 的系列操作

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="pojo"><select id="listStudent" resultType="Student">select * from  student</select><insert id="addStudent" parameterType="Student">insert into student (id, studentID, name) values (#{id},#{studentID},#{name})</insert><delete id="deleteStudent" parameterType="Student">delete from student where id = #{id}</delete><select id="getStudent" parameterType="_int" resultType="Student">select * from student where id= #{id}</select><update id="updateStudent" parameterType="Student">update student set name=#{name} where id=#{id}</update>
</mapper>

parameterType:要求输入参数的类型
resultType:输出的类型

第二步:实现增删改查

package test;import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import pojo.Student;import java.io.IOException;
import java.io.InputStream;
import java.util.List;public class TestMyBatis {public static void main(String[] args) throws IOException {// 根据 mybatis-config.xml 配置的信息得到 sqlSessionFactoryString resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 然后根据 sqlSessionFactory 得到 sessionSqlSession session = sqlSessionFactory.openSession();// 增加学生Student student1 = new Student();student1.setId(4);student1.setStudentID(4);student1.setName("新增加的学生");session.insert("addStudent", student1);// 删除学生Student student2 = new Student();student2.setId(1);session.delete("deleteStudent", student2);// 获取学生Student student3 = session.selectOne("getStudent", 2);// 修改学生student3.setName("修改的学生");session.update("updateStudent", student3);// 最后通过 session 的 selectList() 方法调用 sql 语句 listStudentList<Student> listStudent = session.selectList("listStudent");for (Student student : listStudent) {System.out.println("ID:" + student.getId() + ",NAME:" + student.getName());}// 提交修改session.commit();// 关闭 sessionsession.close();}
}

上述的程序中:

1.通过 session.insert(“addStudent”, student1); 增加了一个 ID 和 studentID 都为 4,名字为“新增加的学生” 的学生

2.通过 session.delete(“deleteStudent”, student2); 删除了 ID = 1 的学生

3.通过 Student student3 = session.selectOne(“getStudent”, 2); 获取了 ID = 2的学生

4.通过 session.update(“updateStudent”, student3); 将 ID = 2 的学生的名字修改为 “修改的学生”

5.通过 session.commit() 来提交事务,也可以简单理解为更新到数据库

运行获得正确结果:


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

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

<select id="findStudentByName" parameterMap="java.lang.String" resultType="Student">SELECT * FROM student WHERE name LIKE '%${value}%'
</select>

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

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

@Test
public void test() throws IOException {// 根据 mybatis-config.xml 配置的信息得到 sqlSessionFactoryString resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 然后根据 sqlSessionFactory 得到 sessionSqlSession session = sqlSessionFactory.openSession();// 模糊查询List<Student> students = session.selectList("findStudentByName", "三颗心脏");for (Student student : students) {System.out.println("ID:" + student.getId() + ",NAME:" + student.getName());}
}

测试结果:

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

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

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

4.关于 “KaTeX parse error: Expected 'EOF', got '#' at position 44: …语句(例如模糊查询时),用 “#̲{}” 是无法达到目的的。在 …{}” 代表一个 “拼接符号” ,可以在原有 SQL 语句上拼接新的符合 SQL 语法的语句。使用 “”拼接符号拼接SQL,会引起SQL注入,所以一般不建议使用“{}” 拼接符号拼接 SQL ,会引起 SQL 注入,所以一般不建议使用 “”拼接符号拼接SQL,会引起SQL注入,所以一般不建议使用“{}”。

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

第一:Java+MyBatis(快速入门)相关推荐

  1. Java基础-SSM之mybatis快速入门篇

    Java基础-SSM之mybatis快速入门篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 其实你可能会问什么是SSM,简单的说就是spring mvc + Spring + m ...

  2. JAVA程序设计-头歌实训-------# 第一阶段 Java语言快速入门

    第一阶段 Java语言快速入门 第1关:Java程序的基本框架:Hello Java World! 任务描述 本关的任务是编写你人生中第一个Java程序,从此开启你的Java实训之旅,显示效果如下: ...

  3. 视频教程-mybatis快速入门到精通-Java

    mybatis快速入门到精通 十年项目开发经验,主要从事java相关的开发,熟悉各种mvc开发框架. 王振伟 ¥18.00 立即订阅 扫码下载「CSDN程序员学院APP」,1000+技术好课免费看 A ...

  4. JAVA WEB快速入门之从编写一个JSP WEB网站了解JSP WEB网站的基本结构、调试、部署...

    接上篇<JAVA WEB快速入门之环境搭建>,在完成了环境搭建后(JDK.Tomcat.IDE),现在是万事具备,就差写代码了,今天就来从编写一个JSP WEB网站了解JSP WEB网站的 ...

  5. MyBatis学习总结(1)——MyBatis快速入门

    2019独角兽企业重金招聘Python工程师标准>>> 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所 ...

  6. mybatis select count(*) 一直返回0 mysql_Mybatis教程1:MyBatis快速入门

    点击上方"Java技术前线",选择"置顶或者星标" 与你一起成长 一.Mybatis介绍 MyBatis是一个支持普通*SQL*查询,存储过程和高级映射的优秀持 ...

  7. MyBatis学习笔记(一)——MyBatis快速入门

    转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4261895.html 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优 ...

  8. java web快速入门_Web安全快速入门

    java web快速入门 Web开发人员针对CORS,CSP,HSTS和所有Web安全首字母缩写词的入门知识! (A web developer's primer on CORS, CSP, HSTS ...

  9. 速看,月薪60K的技术专家总结Java的快速入门.

    作为刚刚接触Java的小白来说,最担心的应该就是Java怎么学,都需要掌握哪些内容?今天这篇文章希望能帮助大家快速入门Java,少走弯路! 如何快速入门Java? 一.作为刚接触Java的新手,肯定要 ...

  10. MyBatis快速入门——第三章、DML语句操作

    MyBatis快速入门--第三章.DML语句操作 目录 在接口类中添加[UsersMapper.java] 修改[com.item.mapper.UsersMapper.] [action.java] ...

最新文章

  1. SQL Server DB Link相关
  2. 华为静态、默认、备用路由配置
  3. 局部和匿名类型作模板实参
  4. linux软件包管理解析,linux学习笔记_09_软件包管理解析.doc
  5. 链路聚合_链路聚合实验
  6. paip.提升用户体验---c++ qt自定义窗体(1)---标题栏的绘制
  7. 【三维路径规划】基于matlab RRT算法无人机三维路径规划【含Matlab源码 1363期】
  8. vasp-分子动力学模拟
  9. 机器视觉的四大类应用
  10. 北京口袋时尚科技公司-微店内推技术一面
  11. JAVA利用httpclient登录开心网
  12. Codeforces Round #677 (Div. 3) C. Dominant Piranha
  13. java共享充电宝管理系统计算机毕业设计MyBatis+系统+LW文档+源码+调试部署
  14. 万年历、黄历,获取每日的宜忌、五行、冲煞、值神、彭祖百忌、吉神宜趋、今日胎神、凶神宜忌、二十八星宿、建除十二神
  15. Linux tmpfs是什么
  16. 北京最牛的医院 最牛的科室排名出炉
  17. 对DHCP客户端创建黑名单或白名单
  18. DETR与Deformable DETR小结
  19. 怎么开启windows hypervisor platform,解决hypervisor platform消失无法安装的问题
  20. 区块链运作机制_什么是区块链及其运作方式?

热门文章

  1. C++库研究笔记——Linux下是否需要使用memory pool?
  2. Oracle分页查询语句(一)
  3. 对一个正整数n,求出n!中末尾0的个数。
  4. IT人不要一直做技术(转载)
  5. eclipse启动报错 Problems occurred when invoking code from plug-in: org.eclipse.jface
  6. MySQL 5.7.18的安装与主从复制
  7. 一 对国家出路的早期探索
  8. JavaScript跨域解决方法大全
  9. POJ培训计划2253_Frogger(最短/floyd)
  10. 什么是创新型人才,创新型企业?