Mybatis面试题整理(超详细)

前端之家收集整理的这篇文章主要介绍了Mybatis面试题整理(超详细)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

<div id="article_content" class="article_content clearfix csdn-tracking-statistics" data-pid="blog" data-mod="popu_307" data-dsm="post">
<h2 class="article-copyright"><span style="color: #000000;">1、什么是Mybatis?
<div id="content_views" class="htmledit_views">

sql语句本身,不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。程序员直接编写原生态sql,可以严格控制sql执行性能,灵活度高。

数据库中的记录,避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。

文件或注解的方式将要执行的各种 statement 配置起来,并通过java对象和 statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射为java对象并返回。(从执行sql到返回result的过程)。

sql语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成任何影响,sql写在XML里,解除sql与程序代码的耦合,便于统一管理;提供XML标签支持编写动态sql语句,并可重用。

代码量,消除了JDBC大量冗余的代码,不需要手动开关连接;

数据库兼容(因为MyBatis使用JDBC来连接数据库,所以只要JDBC支持数据库MyBatis都支持)。

标签,支持对象与数据库的ORM字段关系映射;提供对象关系映射标签支持对象关系组件维护。

sql语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写sql语句的功底有一定要求。

sql语句依赖于数据库,导致数据库移植性差,不能随意更换数据库

sql本身,是一个足够灵活的DAO层解决方案。

性能的要求很高,或者需求变化较多的项目,如互联网项目,MyBatis将是不错的选择。

sql语句。

sql,可以严格控制sql执行性能,灵活度高,非常适合对关系数据模型要求不高的软件开发,因为这类软件需求变化频繁,一但需求变化要求迅速输出成果。但是灵活的前提是mybatis无法做到数据库无关性,如果需要实现支持多种数据库的软件,则需要自定义多套sql映射文件,工作量大。 

数据库无关性好,对于关系模型要求高的软件,如果用hibernate开发可以节省很多代码,提高效率。 

sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;

sql注入,提高系统安全性。

属性名和表中的字段名不一样 ,怎么办 ?

查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致。

    

第2种: 通过来映射字段名和实体类属性名的一一对应的关系。

查询like语句该怎么写?

代码中添加sql通配符。

string wildcardname = “%smi% list names =

sql语句中拼接通配符,会引起sql注入

string wildcardname = list names =

文件,都会写一个Dao接口与之对应,请问,这个Dao接口的工作原理是什么?Dao接口里的方法,参数不同时,方法能重载吗?

Dao接口即Mapper接口。接口的全限名,就是映射文件中的namespace的值;接口的方法名,就是映射文件中Mapper的Statement的id值;接口方法内的参数,就是传递给sql的参数。

Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key值,可唯一定位一个MapperStatement。在Mybatis中,每一个 select * fromuser_user_t whereuser_name = #{0} anduser_area=#{1 (2 (3 文件的命名空间.sql片段的ID,就可以调用对应的映射文件中的sql 方法中只有一个Object参数收集,因此我们使用Map集合来装载我们的参数 Map map = map.put("start" map.put("end" sqlSession.selectList("StudentID.pagination" } sqlSession.rollback(); sqlSession(); }

sql有什么用?执行原理?有哪些动态sql

sql可以在Xml映射文件内,以标签的形式编写动态sql,执行原理是根据表达式的值 完成逻辑判断并动态拼接sql功能

sql标签:trim | where | set | foreach | if | choose | when | otherwise | bind。

文件中,除了常见的select|insert|updae|delete标签之外,还有哪些标签

加上动态sql的9个标签,其中sql片段标签,通过标签引入sql片段,不支持自增的主键生成策略标签

文件中,不同的Xml映射文件,id是否可以重复?

不同的Xml映射文件,如果配置了namespace,那么id可以重复;如果没有配置namespace,那么id不能重复;

原因就是namespace+id是作为Map的key使用的,如果没有namespace,就剩下id,那么,id重复会导致数据互相覆盖。有了namespace,自然id就可以重复,namespace不同,namespace+id自然也就不同。

自动ORM映射工具?它与全自动的区别在哪里?

自动ORM映射工具,使用Hibernate查询关联对象或者关联集合对象时,可以根据对象关系模型直接获取,所以它是全自动的。而Mybatis在查询关联对象或关联集合对象时,需要手动编写sql来完成,所以,称之为半自动ORM映射工具。

查询 ?

 20、MyBatis实现一对一有几种方式?具体怎么操作的?

有联合查询和嵌套查询,联合查询是几个表联合查询,只查询一次, 通过在resultMap里面配置association节点配置一对一的类就可以完成;

嵌套查询是先查一个表,根据这个表里面的结果的 外键id,去再另外一个表里面查询数据,也是通过association配置,但另外一个表的查询通过select属性配置。

21、MyBatis实现一对多有几种方式,怎么操作的?

22、Mybatis是否支持延迟加载?如果支持,它的实现原理是什么?

 23、Mybatis的一级、二级缓存:

24、什么是MyBatis的接口绑定?有哪些实现方式?

接口绑定,就是在MyBatis中任意定义接口,然后把接口里面的方法和SQL语句绑定, 我们直接调用接口方法就可以,这样比起原来了SqlSession提供的方法我们可以有更加灵活的选择和设置。

接口绑定有两种实现方式,一种是通过注解绑定,就是在接口的方法上面加上 @Select、@Update等注解,里面包含Sql语句来绑定;另外一种就是通过xml里面写SQL来绑定, 在这种情况下,要指定xml映射文件里面的namespace必须为接口的全路径名。当Sql语句比较简单时候,用注解绑定, 当SQL语句比较复杂时候,用xml绑定,一般用xml绑定的比较多。

25、使用MyBatis的mapper接口调用时有哪些要求?

②  Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的parameterType的类型相同;
③  Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同;
④  Mapper.xml文件中的namespace即是mapper接口的类路径。

第一种:接口实现类继承SqlSessionDaoSupport:使用此种方法需要编写mapper接口,mapper接口实现类、mapper.xml文件。
(1)在sqlMapConfig.xml中配置mapper.xml的位置

   
   

(2)定义mapper接口
(3)实现类集成SqlSessionDaoSupport
mapper方法中可以this.getSqlSession()进行数据增删改查。
(4)spring 配置
   

第二种:使用org.mybatis.spring.mapper.MapperFactoryBean:
(1)在sqlMapConfig.xml中配置mapper.xml的位置,如果mapper.xml和mappre接口的名称相同且在同一个目录,这里可以不用配置

   
   

(2)定义mapper接口:
①mapper.xml中的namespace为mapper接口的地址
②mapper接口中的方法名和mapper.xml中的定义的statement的id保持一致
③Spring中定义
     
     


第三种:使用mapper
(1)mapper.xml
文件编写:
mapper.xml中的namespace为mapper接口的地址;
mapper接口中的方法名和mapper.xml中的定义的statement的id保持一致;
如果将mapper.xml和mapper接口的名称保持一致则不用在sqlMapConfig.xml中进行配置。 
(2)定义mapper接口:
注意mapper.xml的文件名和mapper的接口名称保持一致,且放在同一个目录
(3)配置mapper扫描器:
   
    sqlSessionfactorybeanName" value="sqlSessionFactory"/> 

(4)使用扫描器后从spring容器中获取mapper的实现对象。

插件运行原理,以及如何编写一个插件

插件,Mybatis使用JDK的动态代理,为需要拦截的接口生成代理对象以实现接口方法拦截功能,每当执行这4种接口对象的方法时,就会进入拦截方法,具体就是InvocationHandler的invoke()方法,当然,只会拦截那些你指定需要拦截方法

插件:实现Mybatis的Interceptor接口并复写intercept()方法,然后在给插件编写注解,指定要拦截哪一个接口的哪些方法即可,记住,别忘了在配置文件中配置你编写的插件

        </div>


            </div>

猜你在找的Java面试题相关文章