一、Mybatis介绍

  MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。

MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动、创建connection、创建statement、手动设置参数、结果集检索等jdbc繁杂的过程代码。

  Mybatis通过xml或注解的方式将要执行的各种statement(statement、preparedStatemnt、CallableStatement)配置起来,并通过java对象和statement中的sql进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射成java对象并返回。

二、使用JDBC的问题总结

  1、数据库连接创建、释放频繁造成系统资源浪费,从而影响系统性能。如果使用数据库连接池可解决此问题。

  2、Sql语句在代码中硬编码,造成代码不易维护,实际应用中sql变化的可能较大,sql变动需要改变java代码。

  3、使用preparedStatement向占有位符号传参数存在硬编码,因为sql语句的where条件不一定,可能多也可能少,修改sql还要修改代码,系统不易维护。

  4、对结果集解析存在硬编码(查询列名),sql变化导致解析代码变化,系统不易维护,如果能将数据库记录封装成pojo对象解析比较方便。

三、Mybatis解决jdbc编程的问题

  1、数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库连接池可解决此问题。

  解决:在SqlMapConfig.xml中配置数据连接池,使用连接池管理数据库链接。

  2、Sql语句写在代码中造成代码不易维护,实际应用sql变化的可能较大,sql变动需要改变java代码。

  解决:将Sql语句配置在XXXXmapper.xml文件中与java代码分离。

  3、向sql语句传参数麻烦,因为sql语句的where条件不一定,可能多也可能少,占位符需要和参数一一对应。

  解决:Mybatis自动将java对象映射至sql语句,通过statement中的parameterType定义输入参数的类型。

  4、对结果集解析麻烦,sql变化导致解析代码变化,且解析前需要遍历,如果能将数据库记录封装成pojo对象解析比较方便。

  解决:Mybatis自动将sql执行结果映射至java对象,通过statement中的resultType定义输出结果的类型。

四、Mybatis架构

  

  1、mybatis配置

  • SqlMapConfig.xml: 此文件作为mybatis的全局配置文件,配置了mybatis的运行环境等信息
  • mapper.xml:sql映射文件,文件中配置了操作数据库的sql语句。此文件需要在SqlMapConfig.xml中加载

  2、SqlSessionFactory:通过mybatis环境等配置信息来构造会话工厂

  3、sqlSession:由会话工厂(SqlSessionFactory)创建,操作数据库需要通过sqlSession进行,SqlSession中封装了对数据库的操作,如:查询、插入、更新、删除等

  4、Executor:mybatis底层自定义了Executor执行器接口操作数据库,Executor接口有两个实现,一个是基本执行器、一个是缓存执行器。

  5、MappedStatement

  • MappedStatement也是mybatis一个底层封装对象,它包装了mybatis配置信息及sql映射信息等。mapper.xml文件中一个sql对应一个MappedStatement对象,sql的id即是MappedStatement的id。

  • MappedStatement对sql执行输入参数进行定义,包括HashMap、基本类型、pojo,Executor通过MappedStatement在执行sql前将输入的java对象映射至sql中,输入参数映射就是jdbc编程中对preparedStatement设置参数。

  • MappedStatement对sql执行输出结果进行定义,包括HashMap、基本类型、pojo,Executor通过MappedStatement在执行sql后将输出结果映射至java对象中,输出结果映射过程相当于jdbc编程中对结果的解析处理过程。

五、Mybatis与hibernate的区别

  Mybatis和hibernate不同,它不完全是一个ORM框架,因为MyBatis需要程序员自己编写Sql语句。mybatis可以通过XML或注解方式灵活配置要运行的sql语句,并将java对象和sql语句映射生成最终执行的sql,最后将sql执行的结果再映射生成java对象。

  Mybatis学习门槛低,简单易学,程序员直接编写原生态sql,可严格控制sql执行性能,灵活度高,非常适合对关系数据模型要求不高的软件开发,例如互联网软件、企业运营类软件等,因为这类软件需求变化频繁,一但需求变化要求成果输出迅速。但是灵活的前提是mybatis无法做到数据库无关性,如果需要实现支持多种数据库的软件则需要自定义多套sql映射文件,工作量大。

  Hibernate对象/关系映射能力强,数据库无关性好,对于关系模型要求高的软件(例如需求固定的定制化软件)如果用hibernate开发可以节省很多代码,提高效率。但是Hibernate的学习门槛高,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡,以及怎样用好Hibernate需要具有很强的经验和能力才行。

  总之,按照用户的需求在有限的资源环境下只要能做出维护性、扩展性良好的软件架构都是好架构,所以框架只有适合才是最好。

转载于:https://www.cnblogs.com/yft-javaNotes/p/10189893.html

Mybatis学习笔记(一) —— mybatis介绍相关推荐

  1. 【最全Mybatis学习笔记(导入mybatis相关jar包)】

    目录 1. 什么是Mybatis 2. 如何引入Mybatis? 3.编写Mybatis工具类 4. 万能Map 5. 模糊查询怎么写? 6. 作用域(Scope)和生命周期SqlSessionFac ...

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

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

  3. mybatis 学习笔记:mybatis 初认识

    简介 MyBatis是一个Java持久层框架,它通过XML描述符或注解把对象与存储过程或SQL语句关联起来.mybatis 可以将 preparedStatement 中的输入参数自动进行映射,将查询 ...

  4. [MyBatis学习笔记] 二、Mybatis基本操作及相关标签介绍

    [MyBatis学习笔记] 二.Mybatis基本操作及相关标签介绍 一.Mybatis简介 二.简单的CRUD操作 1.构建SqlSessionFactory (1)编辑mybatis-config ...

  5. MyBatis多参数传递之Map方式示例——MyBatis学习笔记之十三

    前面的文章介绍了MyBatis多参数传递的注解.参数默认命名等方式,今天介绍Map的方式.仍然以前面的分页查询教师信息的方法findTeacherByPage为例(示例源代码下载地址:http://d ...

  6. ant的下载与安装——mybatis学习笔记之预备篇(一)

    看到这个标题是不是觉得有点奇怪呢--不是说mybatis学习笔记吗,怎么扯到ant了?先别急,请容我慢慢道来. mybatis是另外一个优秀的ORM框架.考虑到以后可能会用到它,遂决定提前学习,以备不 ...

  7. MyBatis多参数传递之混合方式——MyBatis学习笔记之十五

    在本系列文章的<MyBatis多参数传递之Map方式示例>一文中,网友mashiguang提问如下的方法如何传递参数:public List findStudents(Map condit ...

  8. mybatis学习笔记(13)-延迟加载

    2019独角兽企业重金招聘Python工程师标准>>> mybatis学习笔记(13)-延迟加载 标签: mybatis [TOC] resultMap可以实现高级映射(使用asso ...

  9. mybatis学习笔记(7)-输出映射

    2019独角兽企业重金招聘Python工程师标准>>> mybatis学习笔记(7)-输出映射 标签: mybatis [TOC] 本文主要讲解mybatis的输出映射. 输出映射有 ...

最新文章

  1. Oracle RAC系列之:利用srvctl管理RAC数据库
  2. JavaScript函数式编程学习
  3. PIL 学习笔记(3)
  4. poj 1958 Strange Towers of Hanoi
  5. 用Perl做个简单”下载者病毒”
  6. 【软件开发底层知识修炼】二十二 ABI-应用程序二进制接口 二
  7. 光棍节程序员闯关秀过关全攻略
  8. xp 挂linux上网,XP系统挂载Linux NFS共享
  9. rds本地库到rds恢复_阿里云rds 备份和还原
  10. JavaStuNote 5
  11. 使用Cargo入门rust语言
  12. 如何入门短视频剪辑?先要有五大思维,有想法才能有如神助
  13. 洛谷:P1653 猴子(图存储、逆向思维 删边 -->加边)
  14. javaWeb--MVC
  15. 六 R语言barplot条形图之带误差棒的对称条形图及相关性分析结果分布
  16. 元宇宙行业也有冬天!Meta将裁员数千人 小扎狠过马斯克
  17. 5.Python格式化输出
  18. java程序员昵称_Java程序员需要掌握的几个代码命名
  19. java计算机毕业设计智慧农业水果销售系统MyBatis+系统+LW文档+源码+调试部署
  20. 安徽工业大学计算机考研资料汇总

热门文章

  1. 中欧 PHP 开发者大会因多元化争议而取消
  2. java中forward和redirect_好程序员Java教程分享:Forward和Redirect的区别
  3. cocos2d-x 调用java_cocos2d-x中通过Jni实现Java与C++的互相调用
  4. 在python中使用什么函数进行输出_Python中使用pprint函数进行格式化输出的教程
  5. php中怎么替换文字,php里面怎么替换文字
  6. revit二次开发概念_BIM百科 | Revit二次开发入门--创建一个简单的程序
  7. python自动接收邮件_Python自动发送和收取邮件的方法
  8. 知识计算机硬件 教学设计,“计算机硬件系统”教学设计
  9. html字体颜色选择插件,css3改变选择文本背景颜色
  10. java 判断date为空_java – 如何检查JSONArray元素是否为空