mybatis面试题笔记

mybatis是一个优秀的持久层框架,提供了灵活的SQL编写和数据库交互,免除了JDBC代码,支持XML和注解配置,但需要手动编写SQL,适合性能要求高、需求多变的项目。与Hibernate相比,mybatis更注重SQL的灵活性,但移植性较差。mybatis的动态SQL包括where、if、foreach等,支持一对多、延迟加载等功能。在使用中要注意#{}与${}的区别,防止SQL注入。
摘要由CSDN通过智能技术生成

1.什么是mybatis?

答:mybatis是一个优秀的持久层框架,底层封装了JDCB使开发者开发时只用关心sql语句的编写即可。通过简单的Xml配置来映射原生文件,使用pojo映射了数据库数据。免除了几乎所有的JDBC代码,参数设置以及处理结果集。(记忆:免除-封装-数据库)

2.mybatis的优缺点?

答:优点:(1)在xml或注解中直接编写sql代码,比较灵活,方便sql语句的优化和调整(2)免除了重复的JDBC代码(3)与spring易于集成。 缺点:(1)当字段多,涉及多表的操作时,需要编写大量的sql代码(2)sql语句依赖数据库的特性,程序移植性差,不易于切换数据库。(记忆:优(免除-集成-sql)缺:字段-切换)

3.mybatis 与 hibernate 的区别

答:(1)mybatis并不完全是ORM框架,它需要编写sql代码才能和数据库交互,而hibernate则可以做到无sql语句和数据库进行交互(2)mybatis直接编写原生的sql语句,灵活性较高,响应速度快,而hibernate依赖配置自动生成和执行sql语句,面对多变的需求是响应速度就没有那么快(3)mybatis编写大量sql代码时比较考验程序员的功底,效率相对没有那么高,而hibernate不用编写sql代码效率较高(4)mybatis依赖数据库特性,移植性差,不易于切换数据库,而hibernate则屏蔽了数据库的差异,具有较好的一致性。(记忆:有无sql-灵活性-效率-一致性)

4.#{} 和 ${} 的区别

答:mybatis在
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值