什么是MyBatis
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis。是一个基于Java的持久层框架
下面是精心整理的18个MyBatis高频知识及学习笔记,不管处不处在面试阶段的朋友都可以领取保存,以备不时之需
01 18个MyBatis高频知识点(含解析)
1 精讲#{}和${}的区别是什么?
- mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值。
- mybatis在处理时,就是把{}时,就是把时,就是把{}替换成变量的值。
- 使用#{}可以有效的防止SQL注入,提高系统安全性。原因在于:预编译机制。预编译完成之后,SQL的结构已经固定,即便用户输入非法参数,也不会对SQL的结构产生影响,从而避免了潜在的安全风险。
- 预编译是提前对SQL语句进行预编译,而其后注入的参数将不会再进行SQL编译。我们知道,SQL注入是发生在编译的过程中,因为恶意注入了某些特殊字符,最后被编译成了恶意的执行操作。而预编译机制则可以很好的防止SQL注入。
既然{}会引起sql注入,为什么有了#{}还需要有{}呢?那其存在的意义是什么?#{}主要用于预编译,而预编译的场景其实非常受限,而${}用于替换,很多场景会出现替换,而这种场景可不是预编译2 数据库链接中断如何处理?数据库的访问底层是通过tcp实现的,当链接中断是程序是无法得知,导致程序一直会停顿一段时间在这,最终会导致用户体验不好,因此面对数据库连接中断的异常,该怎么设置mybatis呢?connection操作底层是一个循环处理操作,因此可以进行时间有关的参数:
- max_idle_time : 表明最大的空闲时间,超过这个时间socket就会关闭
- connect_timeout : 表明链接的超时时间
数据库服务器活的杠杠的,但是因为网络用塞,客户端仍然连不上服务器端,这个时候就要设置timeout,别一直傻等着3 在开发过程中,经常遇到插入重复的现象,这种情况该如何解决呢?插入的过程一般都是分两步的:先判断是否存在记录,没有存在则插入否则不插入。如果存在并发操作,那么同时进行了第一步,然后大家都发现没有记录,然后都插入了数据从而造成数据的重复解决插入重复的思路 :
- 先判断数据库是否存在数据,有的话则不进行任何操作。没有数据的话,进行下一步;
- 向redis set key,其中只有一个插入操作A会成功,其他并发的操作(B和C…)都会失败的 ;
- 当set key 成功的操作A,开始执行插入数据操作,无论是否插入数据成功,都在需要将redis key删除。【注】插入不成功可以多尝试几次,增加成功的概率 ;
- 然而set key 失败的操作B和C,sleep一下,竞争赢的插入操作重复以上步骤。
总结:多线程同时插入数据,谁获取锁并插入数据成功了其他线程不做任何操作。当插入数据失败后,其他线程抢锁进行插入数据。篇幅有限,完整版18个Mybatis高频知识点如下所示:(需要下载完整版的朋友可以 私信 “学习” 免费领取~~)
18个Mybatis高频知识点
02 32道面试常见的MyBtis题目+解析
1 什么是 MyBatis?答:MyBatis 是一个可以自定义 SQL、存储过程和高级映射的持久层框架。2 讲下 MyBatis 的缓存答:MyBatis 的缓存分为一级缓存和二级缓存,一级缓存放在 session 里面,默认就有,二级缓存放在它的命名空间里,默认是不打开的,使用二级缓存属性类需要实现 Serializable 序列化接口(可用来保存对象的状态),可在它的映射文件中配置3 Mybatis 是如何进行分页的?分页插件的原理是什么?答:1)Mybatis 使用 RowBounds 对象进行分页,也可以直接编写 sql 实现分页,也可以使用Mybatis 的分页插件。2)分页插件的原理:实现 Mybatis 提供的接口,实现自定义插件,在插件的拦截方法内拦截待执行的 sql,然后重写 sql。举例:select * from student,拦截 sql 后重写为:select t.* from (select * from student)tlimit 0,104 简述 Mybatis 的插件运行原理,以及如何编写一个插件?答:1)Mybatis 仅可以编写针对 ParameterHandler、ResultSetHandler、StatementHandler、Executor 这 4 种接口的插件,Mybatis 通过动态代理,为需要拦截的接口生成代理对象以实现接口方法拦截功能,每当执行这 4 种接口对象的方法时,就会进入拦截方法,具体就是InvocationHandler 的 invoke()方法,当然,只会拦截那些你指定需要拦截的方法。2)实现 Mybatis 的 Interceptor 接口并复写 intercept()方法,然后在给插件编写注解,指定要拦截哪一个接口的哪些方法即可,记住,别忘了在配置文件中配置你编写的插件。
篇幅有限,完整版32道面试常见的Mybatis题目+解析如下所示:
32道面试常见的Mybatis题目+解析
03 MyBatis技术内幕(书籍PDF)
MyBatis技术内幕(书籍PDF)
最后分享一波需要文中分享的那些MyBatis全部学习资料的朋友注意啦,转发+私信 “学习”即可免费领取!!!好啦,既然这次谈到了Mybatis,那么顺便这里在给大家分享一下 【SSM框架】的 技术图谱 以及 学习资料
SSM框架技术图谱
SSM框架学习笔记
最后说一次,需要MyBatis以及整个SSM框架的全部学习资料的,转发+转发+转发+私信 “学习” 即可免费获取哦~~