• Mybatis简介


    什么是Mybatis

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

    • MyBatis 是一款优秀的持久层框架
    • 它支持定制化 SQL、存储过程以及高级映射。
    • MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。
    • MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。

    什么是持久化:

    即:数据持久化

    • 持久化就是将程序的数据在持久状态瞬时状态转化的过程
    • 内存:断电即失
    • 数据库(JDBC),IO文件持久化
    • 生活:冷藏.罐头。

    什么是持久层:

    Dao层,Service层,Controller层…

    • 完成持久化工作的代码块
    • 层界限十分明显

    Mybatis的特点

    • 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件。易于学习,易于使用。通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
    • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
    • 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
    • 提供映射标签,支持对象与数据库的orm字段关系映射。
    • 提供对象关系映射标签,支持对象关系组建维护。
    • 提供xml标签,支持编写动态sql。

    为什么要使用MyBatis

    回答这个问题之前,我们要思考:

    1、传统方式JDBC访问数据库会带来哪些不便?

    2、使用mybatis框架访问数据库会带来好处?

    1、传统方式JDBC访问数据库:

    (1)使用JDBC访问数据库有大量重复代码(比如注册驱动、获取连接、获取传输器、释放资源等);

    (2)JDBC自身没有连接池,会频繁的创建连接和关闭连接,效率低

    (3)SQL是写死在程序中,一旦修改SQL,需要对类重新编译

    (4)对查询SQL执行后返回的ResultSet对象,需要手动处理,有时会特别麻烦;

    2、mybatis框架访问数据库:

    (1)Mybatis对JDBC对了封装,可以简化JDBC代码

    (2)Mybatis自身支持连接池(也可以配置其他的连接池),因此可以提高程序的效率

    (3)Mybatis是将SQL配置在mapper文件中,修改SQL只是修改配置文件,类不需要重新编译

    (4)对查询SQL执行后返回的ResultSet对象,Mybatis会帮我们处理,转换成Java对象

    总之,JDBC中所有的问题(代码繁琐、有太多重复代码、需要操作太多对象、释放资源、对结果的处理太麻烦等),在Mybatis框架中几乎都得到了解决!!

    如何获取Mybatis

  • 相关阅读:
    Linux下Docker安装几种NoSQL和MQ
    Go-知识并发控制mutex
    Excel2010打开独立窗口显示的方法
    Hudi SQL DDL
    【Spring Boot 使用记录】kafka自动配置和自定义配置及消费者
    监控 5 分钟抓拍一次人脸,不够 89 次算旷工,居家办公员工:不敢去厕所
    关于卷积神经网络的步幅(stride)
    港口视频管理监控系统
    【XR806开发板试用】XR806简单使用GPIO命令通过继电器远程控制其它开发板
    如何用cmd命令快速搭建FTP服务
  • 原文地址:https://blog.csdn.net/weixin_45737330/article/details/126047738