Mybatis简单介绍
1.什么是Mybatis?
mybatis是一款优秀的持久层框架,它支持普通SQL查询,存储过程和高级映射。
2.Mybatis的思想?
将程序中的大量SQL语句剥离出来,配置在Mapper映射文件中,以实现SQL的灵活配置。这样做的好处是将SQL与程序代码分离,做到可以在不修改程序代码的情况下,直接配置文件中修改SQL。
3.ORM和JPA?
ORM:即对象关系映射,它是一种思想,是指将数据库中的每一行数据用对象的形式表现出来。
JPA:即Java持久化接口,它是JavaEE关于ORM思想的一套标准接口,仅仅是一套接口,不是具体的实现。
4.Mybatis的优点?
a.简单易学,容易上手(相比于Hibernate) — 基于SQL编程
b.消除了JDBC大量冗余的代码,不需要手动开关连接
【Mybatis简单介绍】c.很好的与各种数据库兼容(因为MyBatis使用JDBC来连接数据库,所以只要JDBC支持的数据库MyBatis都支持,而JDB提供了可扩展性,所以只要这个数据库有针对Java的jar包就可以就可以与MyBatis兼容),开发人员不需要考虑数据库的差异性。
d.提供了很多第三方插件(分页插件 / 逆向工程)
e.能够与Spring很好的集成
f.提供xml标签,支持编写动态sql
5.MyBatis框架的缺点? 1. SQL语句的编写工作量较大,尤其是字段多、关联表多时,更是如此,对开发人员编写SQL语句的功底有一定要求。
2. SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。
6.Mybatis和hibernate的区别?
mybatis:
a. 入门简单,即学即用,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。
b. 可以进行更为细致的SQL优化,可以减少查询字段。
c. 缺点就是框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。
d. 二级缓存机制不佳。
hibernate:
a. 功能强大,数据库无关性好,O/R映射能力强,如果你对Hibernate相当精通,而且对Hibernate进行了适当的封装,那么你的项目整个持久层代码会相当简单,需要写的代码很少,开发速度很快,非常爽。
b. 有更好的二级缓存机制,可以使用第三方缓存。
c. 缺点就是学习门槛不低,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡取得平衡,以及怎样用好Hibernate方面需要你的经验和能力都很强才行。
文章图片
推荐阅读
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- mybatisplus如何在xml的连表查询中使用queryWrapper
- mybatisplus|mybatisplus where QueryWrapper加括号嵌套查询方式
- MybatisPlus|MybatisPlus LambdaQueryWrapper使用int默认值的坑及解决
- MybatisPlus使用queryWrapper如何实现复杂查询
- 科学养胃,别被忽悠,其实真的很简单
- opencv|opencv C++模板匹配的简单实现
- 松软可口易消化,无需烤箱超简单,新手麻麻也能轻松成功~
- Apache多路复用模块(MPMs)介绍
- 简单心理2019春A期+32+张荣