spring MyBatis的相关面试题

时间:2024-08-31 14:34:02

(相关面试题! 供参考!)

1.ORM框架有哪些?

MyBatis:半自动化框架(不是纯ORM) 需要写动态SQL语句,实体类和SQL语句之间建立映射关系

Spring:轻量级框架, Java EE的春天,当前主流框架(低耦合 高内聚)

解释ORM : (Object Relational Mapping):表示对象 关系 映射:

    • 编写程序的时候,以面向对象的方式处理数据
    • 保存数据的时候,以关系型数据库的方式存储

2.  MyBatis和Spring的优点 分别是什么?

MyBatis:SQL语句封装在配置文件中,便于统一管理和维护,降低程序的耦合度

了解底层封装过程

方便程序代码调试

Spring: 低侵入式设计

独立于各种应用服务器

依赖注入特性将组件关系透明化,降低了耦合度

面向切面编程特性允许将通用任务进行集中式处理

与第三方框架的良好整合 粘合剂

! !!  Spring也是轻量级框架,站式框架, 可以提供对持久层的支持, 提供Web MVC框架

3.   MyBatis的核心对象有哪些?

SqlSessionFactoryBuilder:

              (1.)用过即丢,其生命周期只存在于方法体内
              (2.)可重用其来创建多个 SqlSessionFactory 实例
              (3.)负责构建SqlSessionFactory,并提供多个build方法的重载---
         SqlSessionFactory
              (1.)SqlSessionFactory是每个MyBatis应用的核心
              (2.)作用:创建SqlSession实例
              (3.)作用域:Application 全局作用域
              (4.)生命周期与应用的生命周期相同
           SqlSession
             (1.)包含了执行SQL所需的所有方法
             (2.)对应一次数据库会话,会话结束必须关闭
             (3.)线程级别,不能共享
             (4.)一个request请求相同
4.如何搭建Mybatis?

1.导入jar包

2.核心配置文件:configuration.xml

3.创建实体类

4.dao层+SQL映射文件-mapper.xml

5.创建测试类:

读取核心文件:mybatis-config.xml

创建SqlSessionFactory对象。读取配置文件

创建SqlSession对象

调用mapper文件进行数据操作

5.MyBatis框架和JDBC相比的优点:
      优点
              与JDBC相比,减少百分之50的代码量
              最简单的持久化框架,小巧并简单易学
              SQL代码从程序代码中彻底分离,可重用
              提供XML标签 支持编写动态SQL
              提供映射标签,支持对象与数据库的ORM字段映射
       缺点
             SQL语句编写工作量大,对其人员有一定要求
              数据库移植性差.
6.resultType和resultMap的区别是什么?
    • resultType是直接表示返回类型 ,基本数据和复杂数据类型
    • resultmap是对外部resultMap的引用 ,数据库字段信息和实体类对象属性不一致,复杂的联合查询,*控制映射结果
    注意!! 二者不能同时存在,本质上都是Map数据结构
7.IOC AOP?谈谈你对它们的理解、
      IOC(Inversion of Control):是一种设计思想 —组件化思想,英文翻译过来就是控制反转—将控制权(创建对象和对象之间的依赖关系的权利)交给spring容器。
    • 控制反转(Inversion of Control)名词,指代内部转外部,将组件对象的控制权从代码本身转移到外部容器
    • 依赖注入(Dependency Injection):操作,在内部拿数据,将组件的构建和使用分开
    • 组件化思想:分离关注点,使用接口,不再关注实现

       补充!!!

    •  轻量级IOC容器:Pico Container、Avalon、Spring、HiveMind等。
    •  超重量级IOC容器:EJB。
    •  半轻半重IOC容器:JBoss,Jdon等。
       AOP (Aspect Oriented Programming):
             所谓面向切面编程,是一种通过预编译和运行期动态代理的方式实现在不修改源代码的情况下给程序动态添加功能的技术
面向切面.
              简单来说就是拿回来拼回去的操作;将程序逻辑相对独立的功能抽取出来(去掉也不影响),利用spring的配置文件将这些功能插进去,提高了代码的复用性.
8.为什么要使用IOC AOP 有什么优点?
    • IOC:解 耦 合—实现组件之间的解耦,实现每个组件时只关注组件内部的事情 ,提高程序的灵活性和可维护性
    • AOP:专心做事,作用主要是改变了OOP(Object Oriented Programming)面向对象编程的不足。
9. MyBatis,增删改查个使用什么标签,有什么属性?
    • 查<select id= “接口中的方法名” resultType="返回值类型/完全限定名" parameterType="传入SQL语句的参数类型/完全限定名"></select>
    • 删<delect id= “接口中的方法名” parameterType=“传入SQL语句的参数类型/完全限定名” ></delect>
    • 改<update  id= “接口中的方法名” parameterType="传入SQL语句的参数类型/完全限定名 “></update>
    • 增<insert  id= “接口中的方法名” parameterType=“传入SQL语句的参数类型/完全限定名 ”></insert>

!!属性:resultType,parameterType

!!传入SQL语句的参数类型可以是:

基础数据类型:int,String,Date 只能传一个,通过 #{参数名} 获取
复杂数据类型:Java实体类,Map等 可通过 属性名或 #{Map的keyName}获取
10. Ajax的属性:
    • url   “发送请求地址”
    • type   “请求方式”
    • data   “发送服务器的数据”
    • dataType    “预期服务器返回的数据类型”
    • success   “成功调用的”
    • error    “请求失败调用的”