• 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

  • 相关阅读:
    zabbix实现钉钉报警
    python计算程序开始、结束以及运行的时间
    SpringBoot开发使用篇
    Java赋值运算符(=)
    qt QRadioButton 及QButtonGroup 使用
    BGP基础
    使DAO具有粘性的四个因素
    数学建模:拟合算法
    【lwip】04-网络数据包流向
    JVM入个门(1)
  • 原文地址:https://blog.csdn.net/weixin_45737330/article/details/126047738