关于面试:锁屏面试题百日百刷Mybatis篇一

46次阅读

共计 3145 个字符,预计需要花费 8 分钟才能阅读完成。


锁屏面试题百日百刷,每个工作日保持更新面试题。锁屏面试题 app、小程序现已上线,官网地址:https://www.demosoftware.cc/#…。已收录了每日更新的面试题的所有内容,还蕴含特色的解锁屏幕温习面试题、每日编程题目邮件推送等性能。让你在面试中后人一步,吊打面试官! 接下来的是今日的面试题:
====Mybatis 中 #和 $ 的区别?
“#” 相当于对数据 加上 双引号,$ 相当于间接显示数据

  1. “#” 将传入的数据都当成一个字符串,会对主动传入的数据加一个双引号。如:order by #user_id#,如果传入的值是 111, 那么解析成 sql 时的值为 order by “111”, 如果传入的值是 id,则解析成的 sql 为 order by “id”.
  2. $ 将传入的数据间接显示生成在 sql 中。如:order by $user_id$,如果传入的值是 111, 那么解析成 sql 时的值为 order by 111, 如果传入的值是 id,则解析成的 sql 为 order by id.
  3. “#” 形式可能很大水平避免 sql 注入。$ 形式无奈避免 Sql 注入。
    4.$ 形式个别用于传入数据库对象,例如传入表名.
    5. 个别能用 #的就别用 $.

====Mybatis 的编程步骤是什么样的?
1、创立 SqlSessionFactory

// 依据 mybatis-config.xml 配置的信息失去 sqlSessionFactory
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new             SqlSessionFactoryBuilder().build(inputStream);

2、通过 SqlSessionFactory 创立 SqlSession
3、通过 sqlsession 执行数据库操作
4、调用 session.commit() 提交事务
5、调用 session.close() 敞开会话

====JDBC 编程有哪些不足之处,MyBatis 是如何解决这些问题的?

  1. 数据库链接创立、开释频繁造成系统资源节约从而影响零碎性能,如果应用数据库链接池可解决此问题。
    解决:在 SqlMapConfig.xml 中配置数据链接池,应用连接池治理数据库链接。
  2. Sql 语句写在代码中造成代码不易保护,理论利用 sql 变动的可能较大,sql 变动须要扭转 java 代码。
    解决:将 Sql 语句配置在 XXXXmapper.xml 文件中与 java 代码拆散。
  3. 向 sql 语句传参数麻烦,因为 sql 语句的 where 条件不肯定,可能多也可能少,占位符须要和参数一一对应。
    解决:Mybatis 主动将 java 对象映射至 sql 语句。
  4. 对后果集解析麻烦,sql 变动导致解析代码变动,且解析前须要遍历,如果能将数据库记录封装成 pojo 对象解析比拟不便。
    解决:Mybatis 主动将 sql 执行后果映射至 java 对象。

==== 应用 MyBatis 的 mapper 接口调用时有哪些要求?

  1. Mapper 接口办法名和 mapper.xml 中定义的每个 sql 的 id 雷同
  2. Mapper 接口办法的输出参数类型和 mapper.xml 中定义的每个 sql 的 parameterType 的类型雷同
  3. Mapper 接口办法的输入参数类型和 mapper.xml 中定义的每个 sql 的 resultType 的类型雷同
  4. Mapper.xml 文件中的 namespace 即是 mapper 接口的类门路。

==== 讲一讲 Mybatis 中一级缓存与二级缓存?

  1. 一级缓存: 基于 PerpetualCache 的 HashMap 本地缓存,其存储作用域为 Session,当 Session flush 或
    close 之后,该 Session 中的所有 Cache 就将清空。
  2. 二级缓存与一级缓存其机制雷同,默认也是采纳 PerpetualCache,HashMap 存储,不同在于其存储作用域为 Mapper(Namespace),并且可自定义存储源,如 Ehcache。作用域为 namespance 是指对该 namespance 对应的配置文件中所有的 select 操作后果都缓存,这样不同线程之间就能够共用二级缓存。启动二级缓存:在 mapper 配置文件中配置 <cache /> 节点。
<mapper namespace="com.yihaomen.mybatis.dao.StudentMapper">
    <!-- 开启本 mapper 的 namespace 下的二级缓存 -->
    <!--
eviction: 代表的是缓存回收策略,目前 MyBatis 提供以下策略。(1) LRU, 最近起码应用的,一处最长工夫不必的对象
        (2) FIFO, 先进先出,按对象进入缓存的程序来移除他们
        (3) SOFT, 软援用,移除基于垃圾回收器状态和软援用规定的对象
        (4) WEAK, 弱援用,更踊跃的移除基于垃圾收集器状态和弱援用规定的对象。这里采纳的是 LRU,移除最长工夫不必的对形象
flushInterval: 刷新间隔时间,单位为毫秒,这里配置的是 100 秒刷新,如果你不配置它,那么当 SQL 被执行的时候才会去刷新缓存。size: 援用数目,一个正整数,代表缓存最多能够存储多少个对象,不宜设置过大。设置过大会导致内存溢出。这里配置的是 1024 个对象
      readOnly: 只读,意味着缓存数据只能读取而不能批改,这样设置的益处是咱们能够疾速读取缓存,毛病是咱们没有方法批改缓存,他的默认值是 false,不容许咱们批改 -->
    <cache eviction="LRU" flushInterval="100000" readOnly="true" size="1024"/>
</mapper>

3. 对于缓存数据更新机制,当某一个作用域 (一级缓存 Session/ 二级缓存 Namespaces) 的进行了 C/U/D 操作后,默认该作用域下所有 select 中的缓存将被 clear。
====MyBatis 如何设置在 insert 插入操作时返回主键 ID?
数据库为 MySql 时:

<insert id="insert" parameterType="com.test.User" keyProperty="userId" 
useGeneratedKeys="true" > 

“keyProperty”示意返回的 id 要保留到对象的那个属性中,“useGeneratedKeys”示意主键 id 为自增长模式。
MySQL 中做以上配置就 OK 了
数据库为 Oracle 时:

<insert id="insert" parameterType="com.test.User">
     <selectKey resultType="INTEGER" order="BEFORE" keyProperty="userId"> 
SELECT SEQ_USER.NEXTVAL as userId from DUAL
</selectKey>
insert into user (user_id, user_name, modified, state)
values (#{userId,jdbcType=INTEGER}, #{userName,jdbcType=VARCHAR}, 
#{modified,jdbcType=TIMESTAMP}, #{state,jdbcType=INTEGER})
</insert>

因为 Oracle 没有自增长一说法,只有序列这种模拟自增的模式,所以不能再应用“useGeneratedKeys”属性。而是应用 <selectKey> 将 ID 获取并赋值到对象的属性中,insert 插入操作时失常插入 id。

更多面试题可关注 ”demo 锁屏面试题 ” 公众号通过小程序或 App 获取面试题和学习资源

正文完
 0