关于mybatis,需要掌握的基础

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
日志服务 SLS,月写入数据量 50GB 1个月
简介: 关于mybatis,需要掌握的基础

 

目录

 

 

❀ 总结 mybatis,需要掌握的基础如下:

1、了解ORM 思想、ORM思想的作用、映射配置的两种方式

2、MyBatis开发流程(基本使用)

3、日志框架

4、了解mybatis生命周期并抽取工具类MyBatisUtil、 MyBatisUtil工具类的作用

5、MyBatis基础拓展(别名、属性、结果集映射、Mapper接口、多参数处理、myBatis插件)

6、注解开发

7、动态SQL

8、对象关联的查询【额外的SQL、 内联映射】和懒加载

9、缓存机制(一级缓存、二级缓存、第三方缓存技术redis、ehcache)

10、代码生成器MyBatis Generator (MBG)、MBG的作用

11、MyBatis 分页插件-PageHelper

❀ 关于mybatis,需要掌握的基础的详情如下:

1、了解ORM 思想  (Object Relational Mapping)   对象映射关系

2、MyBatis基本使用:

3、日志框架使用:

4、了解myBatis的生命周期并抽取工具类MyBatisUtil

5、MyBatis基础拓展(别名、属性、结果集映射、Mapper接口、多参数处理、myBatis插件)

6、注解开发

7、动态SQL

8、对象关联的查询【额外的SQL、 内联映射】和懒加载(在全局配置进行设置)

9、缓存机制(一级缓存、二级缓存、第三方缓存技术redis、ehcache)

10、代码生成器MyBatis Generator (MBG)

11、MyBatis 分页插件-PageHelper


 

 

 

❀ 总结 mybatis,需要掌握的基础如下:

1、了解ORM 思想、ORM思想的作用、映射配置的两种方式

2、MyBatis开发流程(基本使用)

3、日志框架

4、了解mybatis生命周期并抽取工具类MyBatisUtil、 MyBatisUtil工具类的作用

5、MyBatis基础拓展(别名、属性、结果集映射、Mapper接口、多参数处理、myBatis插件)

6、注解开发

7、动态SQL

8、对象关联的查询【额外的SQL、 内联映射】和懒加载

9、缓存机制(一级缓存、二级缓存、第三方缓存技术redis、ehcache)

10、代码生成器MyBatis Generator (MBG)、MBG的作用

11、MyBatis 分页插件-PageHelper

 

 


 

 

 

 

关于mybatis,需要掌握的基础的详情如下:

 

1、了解ORM 思想  (Object Relational Mapping)   对象映射关系

----为了解决面向对象与关系数据库存在的互相不匹配的问题。 [主要是:对象的属性名和表的列名不匹配的问题]

 

■ ORM思想:

面向对象概念----(映射配置)-----面向关系概念

类 ---------------------------------表

对象------------------------------表的行(记录)

属性------------------------------表的列(字段)

 

映射配置Mapping:使用注解/xml

 

 

2、MyBatis基本使用:

-----开发流程-拷贝jar包,编写配置文件,然后进行测试

 

✿ MyBatis全局配置文件内容:

① 属性配置信息

② 全局配置信息(日志信息、)

③ 类型别名

④ 插件配置信息

配置环境信息事务+连接池

关联映射文件

 

✿ MyBatis 映射文件内容:

编写增删改查sql,把sql存放到insert| update| delete| select 元素中去

结果集映射:解决表中的列和对象属性不匹配问题

③ 缓存配置

 

■ 测试myBatis执行增删改查操作:

加载配置文件

创建会话工厂对象SqlSessionFactory【好比连接池DataSource】

建会话对象SqlSession【好比连接对象Connection】

执行crud操作

关闭资源

 

 

3、日志框架使用:

-----开发流程-拷贝jar包,编写日志配置文件,然后在mybatis的全局配置中设置日志信息

 

 

4、了解myBatis的生命周期并抽取工具类MyBatisUtil

-----抽取MyBatisUtil工具类[作用:是用来创建会话对象Sqlsession]

 

■ 通过factory.openSession() 创建会话对象,默认是不提交事务的方式,可以手动提交

 

 

 

5、MyBatis基础拓展(别名、属性、结果集映射、Mapper接口、多参数处理、myBatis插件)

 

■ 别名:在全局配置文件中,配置自定义别名

■ 属性:properties 属性配置 [动态引入]

结果集映射:[ 解决表的列名和对象的属性名不匹配的问题 ]

Mapper 接口:相当DAO 层

多参数处理:使用注解@Param实现处理多个参数

---myBatis默认情况下只能处理一个参数,解决查询多个参数的方法

■ myBatis插件:作用是编写配置文件有代码提示作用

 

 

6、注解开发

 

 

7、动态SQL

  • if
  • choose (when, otherwise)
  • trim (where, set)
  • foreach
  • 其他(bind,sql,include)

 

 

8、对象关联的查询【额外的SQL、 内联映射】和懒加载(在全局配置进行设置)

■ 总结:多对一、一对多关系的单属性对象/集合属性对象,使用association或collection元素?使用额外SQL或内联查询?

● 单属性对象(assoication元素),多表查询操作会选择内联查询

● 集合属性对象(collection元素),懒加载会选择额外SQL处理

 

额外的SQL:会导致N+1 问题

额外的SQL[分步查询],一般需要进入另外一个页面展示更加详细的信息(懒加载)。

内联映射[多表查询],需要在列表中显示关联对象的数据,使用内联映射,否则会出现N+1问题。

 

 

9、缓存机制(一级缓存、二级缓存、第三方缓存技术redis、ehcache)

 

 

10、代码生成器MyBatis Generator (MBG)

-----MBG [作用:可以根据表生成对应的模型对象、Mapper接口、Mapper文件,甚至生成 QBC 风格查询对象。]

 

 

11、MyBatis 分页插件-PageHelper

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
SQL 缓存 Java
MyBatis - 基础篇
MyBatis - 基础篇
199 0
MyBatis - 基础篇
|
SQL XML Java
Mybatis基础笔记五
Mybatis基础笔记五
|
SQL XML Oracle
Mybatis基础笔记四
Mybatis基础笔记四
|
SQL Java 数据库连接
mybatis基础笔记三
mybatis基础笔记三
|
SQL Java 数据库连接
mybatis基础笔记二
mybatis基础笔记二
|
SQL Java 关系型数据库
mybatis基础笔记一
mybatis基础笔记一
|
SQL XML 存储
|
XML 存储 SQL
技术:Java-Web基础|MyBatis整合到SpringBoot(二)
上一篇简单介绍了下MyBatis,知道并了解什么是MyBatis,MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
技术:Java-Web基础|MyBatis整合到SpringBoot(二)
|
SQL XML 存储
技术:Java-Web基础|MyBatis(一)
MyBatis本是Apache的一个开源项目iBatis。目前代码留在Github:https://github.com/mybatis/mybatis-3 ,目前的最新版本是v3.5.10。MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
技术:Java-Web基础|MyBatis(一)
|
SQL Java 关系型数据库
MyBatis(二、基础进阶)
mybatis多表查询,一对一,一对多,多对多 动态sql < if > < foreach > MyBatis映射文件配置
210 0
MyBatis(二、基础进阶)