Mybatis面试题

  • mybatis是什么?其优缺点是什么?

mybatis是ORM框架,提供Java Object到数据库Relation操作的映射,同时提供对JDBC的操作的包装和优化,包括连接池的优化、缓存的优化、事务管理等。

通过构建mapper映射接口和xml配置文件,可以很灵活的做好java实体类和jdbc实体间的映射操作;

  • mybatis的架构和原理?

mybatis的架构主要分为三层:

  1. 接口层:主要是向外提供增删改查的接口。
  2. 数据处理层:主要就是sql和参数传入到结果传出的过程,包括的流程有参数映射、SQL解析、SQL执行、结果映射;
  3. 支撑层:主要负责数据库的连接、事务管理、配置加载还有缓存管理等功能。

mybatis的处理流程包括:

  1. 读取配置文件,生成配置项。通过读取mybati-config.xml配置文件和mapper文件,生成配置项MappedStatement;
  2. 构建会话工厂sqlSessionFactory;这个是mybatis根据configuration来生成的;
  3. 通过sqlSessionFactory构建sqlSession,其中sqlSession就对应一个mapper文件。
  4. 通过执行器Executor来执行解析后的sql;其中每个sql会包装成一个mappedStatement;

一文搞懂Mybatis架构与工作原理:

一文搞懂Mybatis架构与工作原理 - 掘金

  • mybatis的缓存机制?

mybatis有二级缓存管理机制;

  1. 一级缓存管理:在Executor查询database之前,会查询本地缓存,由于每个sqlSession有自己的Executor,所以每个Executor有自己的LocalCache,该缓存查询的key值根据statementId、params、rowBound共同决定;
  2. 二级缓存管理:由于一级缓存知识针对单个sqlSession,针对不同的sqlSession可以配置二级缓存对象,实现多个sqlSession间的缓存共享,可以自己实现cache类也可以引入第三方的缓存服务;
  • mybatis中xml映射文件#{}和${}的区别是什么?
  1. #{}的是在数据库预编译阶段处理,调用PreparedStatement的set方法将#{}占位符替换成?
  2. ${}的处理只是用值替换掉该占位符。使用${}可能有sql注入的风险。

总结:在使用order by和group by语句时,必须要使用${}

  • mybatis中数据库字段名和实体属性名如何映射?

Mybatis查询数据库的结果会保存在ResultSet中,然后将该对象映射到Java对象中,其映射的方式包括以下几种:

  1. 通过数据库字段名和实体属性名映射。这个是默认的映射方式。
  2. 通过设置别名。如果sql语句中设置了别名,会优先使用数据库别名和Java实体属性名进行映射。
  3. 通过ResultMap来设置据库字段名和实体属性名的映射。

  <resultMap id="BaseResultMap" type="com.yangnk.mysqldemo.entity.User1" >

    <id column="id" property="id" jdbcType="INTEGER" />

    <result column="user_name" property="userName" jdbcType="VARCHAR" />

    <result column="password" property="password" jdbcType="VARCHAR" />

    <result column="sex" property="sex" jdbcType="VARCHAR" />

  </resultMap>

  1. 可以自定义TypeHandler,如果以上配置的映射方式无法满足需求,可以自定义TypeHandler来实现数据库字段名和实体属性名之间的映射。
  • mybatis如何实现分页?
  1. 可以在sql中进行limit限制,进行物理分页,也是比较推荐的,一般分页插件是通过这种方式来实现的,通过mybatis提供的插件机制,通过filter拦截sql,对其进行改造,再执行;
  2. 另一种是mybatis自带的分页特性,他主要是通过内存分页来实现的,就是再查询出所有结果到内存中后,再进行内存分页。这个是通过RowBound来实现的,其中指定了offset和limit参数,在全部查询出数据后再进行内存分页。
  • mybatis实现动态SQL的原理?

动态SQL是指可以根据不同的条件生成不同的SQL,这个主要可以通过标签来实现,包括常见的if标签、foreach标签、when标签等。

  • mybatis的Mapper接口为什么没有实现类还能调用?

通过JDK动态代理的方式实现了对目标对象的操作,其实是调用MapperProxy的invoke方法。

  • Mybatis和Hibernate的区别?

Mybatis和Hibernate都是经典的ORM框架,便于Java对象直接操作数据库,他们都能够支持事务管理和缓存管理等特性。

他们的主要区别如下:

  1. Mybatis是半自动的框架,Hibernate是全自动的框架。Mybatis的sql语句需要自己编写,可以编写更复杂和灵活的sql;Hibernate只要配置好数据库关系和Java DO的关系,之后的增删改查操作都能通过Hibernate自动完成。
  2. Mybatis更加灵活和高效,由于其能够自定义sql,所以适应的场景更多;Hibernate相对来说更容易入手,针对只需要简单增删改查的场景是比较方便的。
数据中心机房是现代信息技术的核心设施,它承载着企业的重要数据和服务,因此,其基础设计与规划至关重要。在制定这样的方案时,需要考虑的因素繁多,包括但不限于以下几点: 1. **容量规划**:必须根据业务需求预测未来几年的数据处理和存储需求,合理规划机房的规模和设备容量。这涉及到服务器的数量、存储设备的容量以及网络带宽的需求等。 2. **电力供应**:数据中心是能源消耗大户,因此电力供应设计是关键。要考虑不间断电源(UPS)、备用发电机的容量,以及高效节能的电力分配系统,确保电力的稳定供应并降低能耗。 3. **冷却系统**:由于设备密集运行,散热问题不容忽视。合理的空调布局和冷却系统设计可以有效控制机房温度,避免设备过热引发故障。 4. **物理安全**:包括防火、防盗、防震、防潮等措施。需要设计防火分区、安装烟雾探测和自动灭火系统,设置访问控制系统,确保只有授权人员能进入。 5. **网络架构**:规划高速、稳定、冗余的网络架构,考虑使用光纤、以太网等技术,构建层次化网络,保证数据传输的高效性和安全性。 6. **运维管理**:设计易于管理和维护的IT基础设施,例如模块化设计便于扩展,集中监控系统可以实时查看设备状态,及时发现并解决问题。 7. **绿色数据中心**:随着环保意识的提升,绿色数据中心成为趋势。采用节能设备,利用自然冷源,以及优化能源管理策略,实现低能耗和低碳排放。 8. **灾难恢复**:考虑备份和恢复策略,建立异地灾备中心,确保在主数据中心发生故障时,业务能够快速恢复。 9. **法规遵从**:需遵循国家和地区的相关法律法规,如信息安全、数据保护和环境保护等,确保数据中心的合法运营。 10. **扩展性**:设计时应考虑到未来的业务发展和技术进步,保证机房有充足的扩展空间和升级能力。 技术创新在数据中心机房基础设计及规划方案中扮演了重要角色。例如,采用虚拟化技术可以提高硬件资源利用率,软件定义网络(SDN)提供更灵活的网络管理,人工智能和机器学习则有助于优化能源管理和故障预测。 总结来说,一个完整且高效的数据中心机房设计及规划方案,不仅需要满足当前的技术需求和业务目标,还需要具备前瞻性和可持续性,以适应快速变化的IT环境和未来可能的技术革新。同时,也要注重经济效益,平衡投资成本与长期运营成本,实现数据中心的高效、安全和绿色运行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yangnk42

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值