MyBatis+springMVC

MyBatis概述

MyBatis是一个支持普通SQL查询、存储过程以及高级映射的持久层框架,它消除了几乎所有的JDBC代码和参数的手动设置以及对结果集的检索,并使用简单的XML或注解进行配置和原始映射,用以将接口和Java的POJO(Plain Old Java Object,普通Java对象)映射成数据库中的记录,使得Java开发人员可以使用面向对象的编程思想来操作数据库。

什么是MyBatis

MyBatis框架也被称为ORM(Object/ Relational Mapping,对象关系映射)框架。所谓ORM,就是一种为了解决面向对象与关系型数据库中数据类型不匹配的技术,通过描述Java对象与数据库表之间的映射关系自动将Java应用程序中的对象持久化到关系型数据库的表中。使用ORM框架后,应用程序不再直接访问底层数据库,而是以面向对象的方式来操作持久化对象(Persisent Object,PO),而ORM框架则会通过映射关系将这些面向对象的操作转换成底层的SQL操作。当前的ORM框架产品有很多,常见的ORM框架有Hibernate和MyBatis。
(1)Hibernate:一个全表映射的框架。通常开发者只需定义好持久化对象到数据库表的映射关系,就可以通过Hibernate提供的方法完成持久层操作。开发者并不需要熟练地掌握SQL语句的编写,Hibernate会根据制定的存储逻辑自动生成对应的SQL,并调用JDBC接口来执行,所以其开发效率会高于MyBatis。然而Hibernate自身存在着一些缺点,例如它在多表关联时,对SQL查询的支持较差;更新数据时,需要发送所有字段;不支持存储过程;不能通过优化SQL来优化性能等。这些问题导致其只适合在场景不太复杂且对性能要求不高的项目中使用。
(2)MyBatis:一个半自动映射的框架。这里所谓的“半自动”是相对于
Hibernate全表映射而言的,MyBatis需要手动匹配提供POJO、SQL和映射关系,而Hibernate只需提供POJO和映射关系即可。与Hibernate相比,虽然使用MyBatis手动编写SQL要比使用Hibernate的工作量大,但MyBatis可以配置动态SQL并优化SQL,可以通过配置决定SQL的映射规则,它还支持存储过程等。对于一些复杂的和需要优化性能的项目来说,显然使用MyBatis更加合适。、

MyBatis操作步骤

步骤01 读取配置文件。
步骤02 根据配置文件构建 SqlSessionFactory。
步骤03 通过SqlSessionFactory创建SqlSession。
步骤04 使用SqlSession对象操作数据库(包括查询、添加、修改、删除以及提交事务等)。
步骤05 关闭SqlSession。

MyBatis框架主要涉及两个核心对象:SqlSessionFactory和SqlSession

  • SqlSessionFactory
    SqlSessionFactory是单个数据库映射关系经过编译后的内存镜像,用于创建SqlSession。SqlSessionFactory对象的实例通SqlSessionFactoryBuilder对象来构建 , 通 过 XML 配 置 文 件 或 一 个 预 先 定 义 好 的 Configuration 实 例 构 建 出SqlSessionFactory的实例。通过XML配置文件构建出SqlSessionFactory实例的实现。
    SqlSessionFactory对象是线程安全的,一旦被创建,在整个应用执行期间都会存在。如果多次创建同一个数据库的SqlSessionFactory,那么此数据库的资源将很容易被耗尽。所以在构建SqlSessionFactory实例时,建议使用单列模式。

  • SqlSession
    SqlSession是应用程序与持久层之间执行交互操作的一个单线程对象,其主要作用是执行持久化操作。SqlSession对象包含数据库中所有执行SQL操作的方法,底层封装了JDBC连接,所以可以直接使用其实例来执行已映射的SQL语句。SqlSession实例是不能被共享的,也是线程不安全的,因此其使用范围最好限定在一次请求或一个方法中,绝不能将其放在一个类的静态字段、实例字段或任何类型的管理范围中使用。使用完SqlSession对象之后,要及时将它关闭,通常可以将其放在finally块中关闭。

动态SQL

在这里插入图片描述

1、if 语句
2、if+where 语句
3、if+set 语句
4、choose(when,otherwise) 语句
5、trim 语句
6、SQL 片段
7、foreach 语句

MyBatis缓存机制

MyBatis的查询缓存分为一级缓存和二级缓存。
在这里插入图片描述

一级缓存(SqlSession级别)

一级缓存是SqlSession级别的缓存,在操作数据库时需构造SqlSession对象,在 SqlSession对象中有一个HashMap 用于存储缓存数据。不同的SqlSession 之间的缓存数据区域(HashMap)是互相不影响的。

一级缓存的作用域是SqlSession范围,当同一个SqlSession执行两次相同的SQL语句时,第一次执行完后会将数据库中查询的数据写到缓存中,第二次查询时直接从缓存获取,不用去数据库查询。当SqlSession执行insert、update、delete操作并将结果提交给数据库时,会清空缓存,保证缓存中的信息是最新的。

需要注意的是,如果SqlSession执行了DML操作(insert、update和delete),并提交到数据库,MyBatis则会清空SqlSession中的一级缓存,这样做的目的是为了保证缓存中存储的是最新的信息,避免出现脏读现象。当一个SqlSession结束后该SqlSession中的一级缓存也就不存在了。Mybatis默认开启一级缓存,不需要进行任何配置。

注意 :
MyBatis的缓存机制是基于id进行缓存的,也就是说,MyBatis使用HashMap缓存数据时,是使用对象的id作为key,对象作为value保存的。

在这里插入图片描述
在这里插入图片描述

二级缓存是 mapper 级别的缓存。

二级缓存是Mapper级别的缓存,同样是基于HashMap进行存储的,多个SqlSession可以共用二级缓存,其作用域是Mapper的同一个namespace。不同的SqlSession两次执行相同的namespace下的SQL语句,会执行相同的SQL,第二次查询只会查询第一次查询时读取数据库后写到缓存的数据,不会再去数据库查询。

MyBatis默认没有开启二级缓存,需要在setting全局参数中配置开启二级缓存。
在这里插入图片描述

在这里插入图片描述

Mybatis和hibenate的区别

  • Mybatis 半自动化模式操作数据,hibenate完全面向对象操作数据
  • Mybatis运行的性能高于hibernate的性能
  • Mybatis开发速度低于hibernate的开发速度
  • Mybatis应用在互联网项目的开发,Hibernate用在传统的MIS系统开发

第二部分 SpringMVC

SpringMVC的执行流程

在这里插入图片描述

SpringMVC数据绑定

在这里插入图片描述
1、默认支持的类型
SpringMVC 有支持的默认参数类型,我们直接在形参上给出这些默认类型的声明,就能直接使用了。如下:
  ①、HttpServletRequest 对象
  ②、HttpServletResponse 对象
  ③、HttpSession 对象
  ④、Model/ModelMap 对象
  
Controller代码:

@RequestMapping("/defaultParameter")
    public ModelAndView defaultParameter(HttpServletRequest request,HttpServletResponse response,
                            HttpSession session,Model model,ModelMap modelMap) throws Exception{
        request.setAttribute("requestParameter", "request类型");
        response.getWriter().write("response");
        session.setAttribute("sessionParameter", "session类型");
        //ModelMap是Model接口的一个实现类,作用是将Model数据填充到request域
        //即使使用Model接口,其内部绑定还是由ModelMap来实现
        model.addAttribute("modelParameter", "model类型");
        modelMap.addAttribute("modelMapParameter", "modelMap类型");
         
        ModelAndView mv = new ModelAndView();
        mv.setViewName("view/success.jsp");
        return mv;
    }

2、基本数据类型的绑定

byte
short
int
long
float
double
char
boolean

在这里插入图片描述
3、包装数据类型的绑定
问题:我们这里的参数是基本数据类型,如果从前台页面传递的值为 null 或者 “”的话,那么会出现数据转换的异常,就是必须保证表单传递过来的数据不能为null或”",所以,在开发过程中,对可能为空的数据,最好将参数数据类型定义成包装类型,具体参见下面的例子。

包装类型如Integer、Long、Byte、Double、Float、Short,(String 类型在这也是适用的) ,这里我们以 Integer 为例
在这里插入图片描述
4、POJO(实体类)类型的绑定
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
5、复合POJO(实体类)类型的绑定
6、数组类型的绑定
在这里插入图片描述
7、List类型的绑定
在这里插入图片描述
在这里插入图片描述
8、Map类型的绑定
在这里插入图片描述
在这里插入图片描述
①、form表单无法提交input输入框属性设置为 disabled 的内容

< input type="text" disabled="disabled" name="metadataName"   maxlength="50" placeholder="这里输入模型英文名称" title="模型英文名称" "/>

具有 disabled=“disabled” 的属性,提交到 Controller后,metadataName 的值为null

解决办法:改为 readonly="readonly"
  readonly:针对input(text / password)和textarea有效,在设置为true的情况下,用户可以获得焦点,但是不能编辑,在提交表单时,输入项会作为form的内容提交。

disabled:针对所有表单元素(select,button,input,textarea等),在设置为disabled为true的情况下,表单输入项不能获得焦点,用户的所有操作无意义,在提交表单时,表单输入项不会被提交。

在这里插入图片描述

json数据交互和restful支持

在这里插入图片描述

拦截器

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

花乐晴

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

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

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

打赏作者

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

抵扣说明:

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

余额充值