官网

http://www.mybatis.org/mybatis-3/zh/index.html

GitHub

https://github.com/mybatis/mybatis-3

简介

MyBatis 本是 apache 的一个开源项目 iBatis

2010年这个项目由 apache software foundation 迁移到了 google code ,并且改名为 MyBatis

2013年11月迁移到 Github

MyBatis 是一款优秀的基于 Java持久层框架

MyBatis 是一个半自动化的ORM (Object Relationship Mapping) 框架 --> 对象关系映射

MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的过程。

MyBatis 可以使用简单的 XML注解来配置和映射原生信息,将接口和 Java 的实体类映射成数据库中的记录。

持久化

持久化是将程序数据在持久状态和瞬时状态间转换的机制

核心就是把数据(如内存中的数据)保存到可永久保存的存储设备中(如磁盘)。

JDBC 就是一种持久化机制;文件 IO 也是一种持久化机制。

为什么需要持久化

内存本身的缺陷引起的,因为内存断电后数据会丢失。

有一些重要数据是无论如何都不能丢失的,但无法保证内存永不掉电。

内存过于昂贵,而且维持成本也高,需要一直供电。

即使对象不需要永久保存,也会因为内存的容量限制不能一直呆在内存中,需要持久化来缓存到外存。

持久层

完成持久化工作的代码块(如DAO层、Mapper层)。

现在的企业应用持久化的实现过程大多是通过各种关系数据库来完成。

持久层是一个独立的层级,用于处理数据,为了层级职责清晰,不建议在该层编写业务逻辑。

优点

复用

传统的 JDBC 操作,有很多重复代码块,会造成一定的代码冗余。

MyBatis 由于将 SQL 语句独立成了接口,可以增加代码的复用性,减少冗余代码。

轻量

MyBatis 很小巧,最简单安装只需要两个 jar 包和配置几个 SQL 映射文件就可以。

无侵入

没有任何第三方依赖,不会对应用程序或者数据库的现有设计强加任何影响。

灵活

提供 XML 标签,支持编写动态 SQL。

易于管理

SQL 语句写在 XML 里,便于统一管理和优化。

强大

通过 SQL 语句可以满足操作数据库的所有需求。

解耦

通过提供 DAO 层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,易于维护和进行单元测试。

活跃

Mybatis 是国内最流行的 Java 持久层框架,可以和众多框架集成,有非常活跃的社区,版本迭代和维护也较为频繁。

MyBatis 01 概述的更多相关文章

  1. Hello Mybatis 01 第一个CRUD

    What's the Mybatis? MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google c ...

  2. 01 - 概述 VTK 6.0 迁移

    摘要 对vtk版本4和5的管道机制重新架架构的主要目的是:迁移数据对象和算法对象中的管道执行逻辑到一个新集合的类中,我们称这个集合类叫executives.分离数据和执行模型的代码后,可以双双简化修改 ...

  3. MyBatis框架概述

    MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注SQL本身,而不需要花费精力去处理例如注册驱动.创建connection.创建statement.手动设 ...

  4. Redis数据库 01概述| 五大数据类型

    1.NoSQL数据库简介 解决应用服务器的CPU和内存压力:解决数据库服务的IO压力: ----->>> ① session存在缓存数据库(完全在内存里),速度快且数据结构简单: 打 ...

  5. Hive 01 概述、安装配置

    概述 数据仓库:是一个面向主题的.集成的.不可更新的.随时间不变化的数据集合,它用于支持企业或组织的决策分析处理. 数据仓库的结构和建立过程: 数据源 数据存储及管理 ETL Extract 提取 T ...

  6. 【OracleDB】 01 概述和基本操作

    实例概念: Oracle有一个特殊的概念 Oracle数据库 = 数据库 + Oracle文件系统 + Oracle实例 实例处理Oracle的请求,调用文件系统 然后返回结果响应给客户端 单实例和多 ...

  7. 框架学习-MyBatis(01)

    1.MyBatis是持久层框架 什么是持久化: 狭义:把数据永久性的保存到数据当中 广义:针对于数据库的所有操作都称为持久化操作,CreateReadUpdateDelete操作 2.有哪些持久层框架 ...

  8. Headfirst JSP 01 (概述)

    HTTP 协议 http 是tcp/ip上层协议, 如果你对这些网络协议还不是太熟悉, 下面提供一个非常简单的解释, tcp负责确保从一个网络节点向另一个网络节点发送文件能作为一个完整的文件到达目的地 ...

  9. Python学习笔记 :01概述

    Python基础 首先推荐学习Python基础的教程和书籍 视频教程推荐南京大学张莉老师在cousera上的教程用Python玩转数据 入门教程<Python基础教程> 数据挖掘教程< ...

随机推荐

  1. 树形dp基础

    今天来给大家讲一下数形dp基础 树形dp常与树上问题(lca.直径.重心)结合起来 而这里只讲最最基础的树上dp 1.选课 题目描述 在大学里每个学生,为了达到一定的学分,必须从很多课程里选择一些课程 ...

  2. 【freertos】010-消息队列概念及其实现细节

    目录 前言 10.1 消息队列概念 10.2 消息队列的数据传输机制 10.3 消息队列的阻塞访问机制 10.4 消息队列使用场景 10.5 消息队列控制块 10.5.1 队列控制块源码 10.5.2 ...

  3. while循环结构

    一.循环: 1.场景: ①.用户名和密码,反复输入 ②.计算1-100之间 ③.游戏,重生 ④.-- 2.方式 ①.while ②.for 3.while格式 while 条件:要循环执行的代码 布尔 ...

  4. Puppeteer学习笔记 (2)- Puppeteer的安装

    本文链接:https://www.cnblogs.com/hchengmx/p/11009849.html 1. node的下载安装 由于puppeteer是nodejs的一个库,所以首先需要安装no ...

  5. php判断客户端浏览器类型

    /** * 判断浏览器名称和版本 */ function get_user_browser() { if (empty($_SERVER['HTTP_USER_AGENT'])) { return ' ...

  6. CSRF跨站请求伪造与XSS跨域脚本攻击讨论

    今天和朋友讨论网站安全问题,聊到了csrf和xss,刚开始对两者不是神明白,经过查阅与讨论,整理了如下资料,与大家分享. CSRF(Cross-site request forgery):跨站请求伪造 ...

  7. 快速全面了解QT软件界面开发技术

    快速全面了解QT软件界面开发技术     目录 前言 一. 学习QT可能的目的是什么? 只想体验一下QT? 当前的项目选择了用QT. 为将来做QT技术储备. 二. QT的核心技术优势是什么? QT在软 ...

  8. 什么是AR技术?AR的价值究竟有多大?

    什么是AR技术? AR技术,解释来说就是增强现实(Augmented Reality),是一种实时地计算摄影机影像的位置及角度并加上相应图像.3D模型的技术,它的目标是把虚拟世界嵌套进真实世界进行互动 ...

  9. NET架构师的基本职责

    NET架构师的基本职责1 职责 对本公司大健康平台提出技术研究及可行性报告; 结合需求设计高扩展性.高性能.安全.稳定.可靠的技术系统; 可以通过配置实现业务需求的变化,跟踪并研究***并应用于产品; ...

  10. 使用C++的ORM框架QxORM

    QxORM中,我们用的最多的无非是这两点 官方表述是这样的: 持久性: 支持最常见的数据库,如 SQLite.MySQL.PostgreSQL.Oracle.MS SQL Server.MongoDB ...