5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

mybatis配置详解

===========

1 核心配置文件

  • mybatis-confifig.xml 系统核心配置文件

  • MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息

  • 一些属性和配置内容说明:

configuration(配置)

properties(属性)

settings(设置)

​ typeAliases(类型别名)

​ typeHandlers(类型处理器)

​ objectFactory(对象工厂)

​ plugins(插件)

​ environments(环境配置)

​ environment(环境变量)

​ transactionManager(事务管理器)

​ dataSource(数据源)

​ databaseIdProvider(数据库厂商标识)

​ mappers(映射器)

2 environments(环境配置)

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

根据生产上的要求,不同部门可能需要不同环境,可以配置多套环境,但是只能同时使用一个,且必须指定其中一个为默认运行环境(通过default指定)

子元素节点:environment

具体的一套环境,通过设置id进行区别,id保证唯一!

  • 子元素节点:transactionManager - [ 事务管理器 ]

MyBatis 中有两种类型的事务管理器(也就是 type=“[JDBC|MANAGED]”)在单独的mybatis中不需要进行额外配置

  • 子元素节点:dataSource(数据源)

dataSource 元素使用标准的 JDBC 数据源接口来配置 JDBC 连接对象的资源。

有三种内建的数据源类型(type=“[UNPOOLED|POOLED|JNDI]"))

3 mappers(映射器)

映射器 : 定义映射SQL语句文件

3.1 引入资源的不同方式

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

3.2 Mapper文件模板

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

4 properties(属性)

  • properties 属性可以利用配置文件或者java代码来动态更改

  • 在多处中配置了属性时,propertie中的值会被resouce中的覆盖,会被java代码中的方法传参覆盖。

  • 可以采用占位符的形式来配置属性默认值官方文档

4.1使用配置文件优化

新建config.properties

导入配置文件并占位符显示属性值

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

5 typeAliases(别名)

为解决包名过长问题的代码冗余。

第一种方式

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

在所有使用com.lyj.entity.UserInf的地方都可以用User代替

第二种方式

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

在com.lyj.entity包下的所有实体类都可以使用类名首字母小写的方式引用(如com.lyj.entity.UserInf用userInf代替)

也可以在实体类加上注解的方式自定义别名

@Alias(“user”)

public class UserInf { … }

6 settings(设置)

可以为mybatis增加设置

数据库驼峰名转换设置

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

log日志设置显示

ResultMap(结果集映射)

================

为了解决数据映射问题而生

1 解决数据库与实体类属性名不一致问题

解决的问题:属性名和字段名不一致

因为各种原因,数据库的属性字段无法和实体类的属性字段一一对应。

举例:

现在数据库表属性为:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

实体类属性值为:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

查询语句:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

这样查询,因为pwd在实体类中并不存在,在注入值时无法注入。出现password属性为空的情况。

解决方案

使用别名(可简写 pwd password)

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

使用结果集映射->ResultMap 【推荐】

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

2 解决多对一结果集映射(association关联属性)

多对一理解:

  • 多个学生对应一个老师。

  • 数据库概念理解:学生拥有一个tid与教师id对应。

  • 实体类概念理解:学生拥有一个教师对象。

2.1 按查询嵌套处理

实体类student和teacher

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

StudentMapper增加接口

//查询所有学生

public List queryAllStudents();

StudentMapper.xml增加对应方法(对于对象属性teacher采用关联属性)

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

测试(对于对象属性teacher的属性采用关联属性)

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

2.2 按结果嵌套处理。

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

3解决一对多结果集映射(collection集合)

一对多理解:

  • 一个老师有多个学生

  • 数据库概念理解:教师拥有一个id与学生tid对应。

  • 实体类概念理解:教师拥有一个学生对象List集合。

3.1 按查询嵌套处理。

实体类Student和Teacher

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

TeacherMapper增加方法

public Teacher getTeacher(int id);

TeacherMapper.xml增加实现

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

测试

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

3.2 按结果嵌套处理

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

动态SQL

=====

动态SQL指的是根据不同的查询条件 , 生成不同的Sql语句。

1 环境

utils工具类:随机生成id

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

entity实体类

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

其他正常布置,数据库添加数据。

2 if语句

需求:根据作者名字和博客名字来查询博客!如果作者名字为空,那么只根据博客名字查询,反之,则根据作者名来查询

xml文件实现

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

注意:在依次执行所有的if语句,因此当title为空,author不为空时,产生错误。引入where

3 where语句

xml文件实现

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

注意:当where包含的标签有返回值时能够自动加上where字符,同时当检测标签开头含有 AND或 OR 字符时,会将字符除去。

4 choose语句

利用if 和where搭配已经能够解决大部分的SQL查询拼接,但是有时候我们需要某一个条件不为空时立即跳出不在接受参数。这个时候我们可以利用choose实现,相当于编程语言中的 switch。

xml实现:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

读起来十分有switch-case-otherwise的既视感。

5 foreach语句

foreach 相当于for循环,当我们需要一次性查询多个内容时,可以用foreach来实现这一功能。

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

测试:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

相当于SQL语句:select * from blog where (id=1 or id=2 or id=3)

6 set语句

当我们需要进行修改操作时,set的操作配合if使用会现之前查询出现的问题。

不用set标签之前,当author为空时,名=SQL语句拼接就会出错,这个时候使用set标签可以很好的解决这个问题。

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

使用set标签后

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

**set标签的功能和where类似,先是内部标签有返回值时会自动补充set字符,当内部标签结尾含有,字符时,会自动去除 **

7 SQL片段

在正常的数据查询流程中,直接使用select *对数据安全来说无疑是十分危险的,我们会使用字段的形式来代替这种方式,但是字段过多的情况下,每次重复的复制代码过于麻烦且不容易维护。这个时候自定义SQL片段可以很好的解决这个问题。

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

sql标签和incloud标签配合使用很好的实现了这个功能。

日志工厂与分页

=======

1 日志工厂

mybatis可以通过配置日志的方式来过程信息,可以采用自带的日志工厂,也可以用第三方包。

Mybatis内置的日志工厂提供日志功能,具体的日志实现有以下几种工具:

  • SLF4J

  • Apache Commons Logging

  • Log4j 2

  • Log4j

  • JDK logging

标准日志实现:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

2 Log4j

通过使用Log4j,我们可以控制日志信息输送的目的地:控制台,文本,GUI组件…

我们也可以控制每一条日志的输出格式;

使用:

导包

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

更改日志工厂设置

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

新建配置文件log4j.properties

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

使用

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

**注意:**log4j导包使用的是apache的包,会自动在当前目录生成一个log文件夹,可以显示log记录。

3 limit实现分页

**分页:**记得以前一个javaweb项目当中,老师要求使用java代码来实习分页查询。那个时候是使用了一个工具类来专门处理分页逻辑,现在回顾过去,也不是十分困难。

主要有两个方法,一是在MySQL层次上处理,另一个是在java代码层次上。

3.1 分页实现

mysql语法:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

步骤:

SQL语句

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

如果我们有很多种不同的分页类型,为每一个不同的类型写不同的工具类就会让代码十分的冗余,用泛型可以解决这一问题。

blog实体类

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

PageModel泛型类,来实现一个基本的分页数据。

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

如果想要在PageModel的基础上加上具有不同分页特色的数据,那么可以用继承来实现。

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

工具类处理

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

测试类

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

之前以为这样就完成了分页,没想到始终无法将Mapper抽象出来,这个分页是不合格的。

3.2 RowBounds分页

使用方法

3.3 PageHelper

使用方法

mybatis缓存

=========

1 简介

什么是缓存 [ Cache ]?

  • 存在内存中的临时数据。

  • 将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题。

为什么使用缓存?

  • 减少和数据库的交互次数,减少系统开销,提高系统效率。

什么样的数据能使用缓存?

  • 经常查询并且不经常改变的数据。

2 Mybatis缓存

MyBatis包含一个非常强大的查询缓存特性,它可以非常方便地定制和配置缓存。缓存可以极大地提升查询效率。

MyBatis系统中默认定义了两级缓存:一级缓存和二级缓存

  • 默认情况下,只有一级缓存开启。(SqlSession级别的缓存,也称为本地缓存)

  • 二级缓存需要手动开启和配置,它是基于namespace级别的缓存。

  • 为了提高扩展性,MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存

3 一级缓存

一级缓存也称为本地缓存。

默认开启的。

SqlSession级别的缓存。

在同一个session中我们执行同一个查询,将不会重复的去sql读取,而是从缓存中去读取。

3.1 一级缓存失效的四种情况
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Java)

总目录展示

该笔记共八个节点(由浅入深),分为三大模块。

高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。

一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。

高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。


篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)

由于内容太多,这里只截取部分的内容。
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
涵盖了95%以上Java开发知识点,真正体系化!**

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Java)

[外链图片转存中…(img-mxSSXWPb-1713804317190)]

总目录展示

该笔记共八个节点(由浅入深),分为三大模块。

高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。

一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。

高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。


篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)

[外链图片转存中…(img-CKZnydBZ-1713804317190)]

[外链图片转存中…(img-jDgZ9zAw-1713804317190)]

由于内容太多,这里只截取部分的内容。
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 25
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值