参考文章:
Mybatis常见面试题总结_面试_a745233700的博客-CSDN博客blog.csdn.net1、什么是Mybatis
?
MyBatis
是一个优秀的持久层框架,是一个半ORM
(对象关系映射)框架,它对jdbc
的操作数据库的过程进行封装,使开发者只需要关注SQL
本身,而不需要花费精力去处理例如加载驱动、创建连接、创建statement等繁杂的过程。
Mybatis
通过xml
或注解的方式将要执行的statement
配置起来,并通过java
对象和statement
中的sql
进行映射生成最终执行的sql
语句,最后由mybatis
框架执行sql
并将结果映射成java
对象并返回。
2、Mybatis
的优点与缺点?
优点:
- 基于
SQL
语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成任何影响,SQL
写在XML
里,解除sql
与程序代码的耦合,便于统一管理;提供XML标签,支持编写动态SQL
语句,并可重用。 - 与
JDBC
相比,减少了JDBC
大量冗余的代码,不需要手动开关连接 - 很好的与各种数据库兼容
- 能够与
Spring
很好的集成 - 提供映射标签,支持对象与数据库的
ORM
字段关系映射;提供对象关系映射标签,支持对象关系组件维护。
缺点:
SQL
语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写SQL
语句的功底有一定要求。SQL
语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。
3、#{}和${}的区别是什么?
#{}是预编译处理,${}是字符串替换。
Mybatis
在处理#{}时,会将sql
中的#{}替换为?(占位符)号,调用PreparedStatement
的set
方法来赋值;
Mybatis
在处理${}时,就是把${}替换成变量的值。
使用#{}可以有效的防止SQL
注入,提高系统安全性。
4、Mybatis
和Hibernate
有什么区别?
Mybatis
和hibernate</