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