浅谈MyBatis

什么是MyBatis

1: Mybatis是一个半ORM(对象关系映射)框架,它内部封装了JDBC,开发时只需要关注SQL

语句本身,不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。程序员直

接编写原生态sql,可以严格控制sql执行性能,灵活度高。
2: MyBatis 可以使用 XML 或注解来配置和映射原生信息,将 POJO映射成数据库中的记录,避

免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。
3: 通过xml 文件或注解的方式将要执行的各种 statement 配置起来,并通过java对象和

statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果

映射为java对象并返回。(从执行sql到返回result的过程)。

MyBatis的优点和缺点

优点:
1: 基于SQL语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成任何影响,SQL写

在XML里,解除sql与程序代码的耦合,便于统一管理;提供XML标签,支持编写动态SQL语句,并

可重用。
2: 与JDBC相比,减少了50%以上的代码量,消除了JDBC大量冗余的代码,不需要手动开关连接;
3: 很好的与各种数据库兼容(因为MyBatis使用JDBC来连接数据库,所以只要JDBC支持的数据

库MyBatis都支持)。
4: 能够与Spring很好的集成;
5: 提供映射标签,支持对象与数据库的ORM字段关系映射;提供对象关系映射标签,支持对象关系组件维护。

缺点:
1: SQL语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写SQL语句的功底有

一定要求。
2: SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。

Mybatis分页插件的原理

Mybatis使用RowBounds对象进行分页,它是针对ResultSet结果集执行的内存分页,而非物理分

页。可以在sql内直接拼写带有物理分页的参数来完成物理分页功能,也可以使用分页插件来完成物

理分页,比如:MySQL数据的时候,在原有SQL后面拼写limit。

分页插件的基本原理是使用Mybatis提供的插件接口,实现自定义插件,在插件的拦截方法内拦截

待执行的sql,然后重写sql,根据dialect方言,添加对应的物理分页语句和物理分页参数。

Mybatis将sql执行结果封装为目标对象并返回的方式 以及用到的映射形式

第一种 是使用标签,逐一定义数据库列名和对象属性名之间的映射关系。
第二种 是使用sql列的别名功能,将列的别名书写为对象属性名。

有了列名与属性名的映射关系后,Mybatis通过反射创建对象 ,同时使用反射给对象的属性逐一赋

值并返回,那些找不到映射关系的属性,是无法完成赋值的。

相关推荐
曹牧5 分钟前
Oracle数据库中,将JSON字符串转换为多行数据
数据库·oracle·json
jnrjian1 小时前
text index 查看index column index定义 index 刷新频率 index视图
数据库·oracle
韶博雅1 小时前
emcc升级
oracle
迷枫7122 小时前
达梦数据库的体系架构
数据库·oracle·架构
夜晚打字声3 小时前
9(九)Jmeter如何连接数据库
数据库·jmeter·oracle
NineData3 小时前
NineData 智能数据管理平台新功能发布|2026 年 3 月
数据库·oracle·架构·dba·ninedata·数据复制·数据迁移工具
夕除3 小时前
javaweb--02
java·tomcat
不愿透露姓名的大鹏4 小时前
Oracle归档日志爆满急救指南
linux·数据库·oracle·dba
卓怡学长6 小时前
m326数据结构课程网络学习平台的设计与实现+vue
java·spring·tomcat·maven·intellij-idea·mybatis
jnrjian6 小时前
Oracle text index 更新机制
oracle