绝了!想都不敢想会有这么全的MySQL学习笔记,从基础到进阶,简单但精悍,全是重点~

本文主要是介绍绝了!想都不敢想会有这么全的MySQL学习笔记,从基础到进阶,简单但精悍,全是重点~,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

MyBatis本是apache的一个开源项目iBatis,2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis。是一个基于Java的持久层框架。

在国内市场来说,Mybatis的使用率比Hibernate更高,也更加流行。个人认为其流行的主要原因在于:国内绝大部分项目都是面向表结构编程的,Mybatis使用起来更加方便。

Alibaba绝对是国内互联网行业的天花板,很多优秀的开源项目都是阿里大佬分享出来的,因此今天就跟大家分享一份连Alibaba内部都在消化的Mybatis学习笔记,内容不算多,但把重点讲的明明白白,下面一起看一下吧!

关于这份笔记,我只能在文章中展示部分的章节内容和核心截图:

Mybatis入门

1、什么是Mybatis?

MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。

2、为什么要用Mybatis?

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

3、Mybatis快速入门

  • 导入开发包
  • 准备测试工作
  • 创建mybatis配置文件
  • 编写工具类测试是否获取到连接
  • 创建实体与映射关系文件
  • 编写DAO

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

4、Mybatis工作流程

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

5、完成CRUD操作

  • 增加学生
  • 2根据ID查询数据
  • 查询所有数据
  • 根据id删除
  • 修改
  • 小细节
  • Mybatis分页

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

6、动态SQL

  • 动态查询
  • 动态更新
  • 动态删除
  • 动态插入

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis配置信息

1、映射文件

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

2、配置文件

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

关联映射

Mybatis【多表连接】

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

缓存+Mapper代理+逆向工程

1、Mybatis缓存

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

2、mybatis和ehcache缓存框架整合

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

3、Mapper代理方式

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

4、Mybatis解决JDBC编程的问题

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

5、Mybatis逆向工程

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis整合Spring

1、Mybatis与Spring整合

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis常见面试题

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis源码——入门

  • 为什么要使用MyBatis
  • 如何使用MyBatis

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis源码——配置文件解析过程

配置文件解析过程分析

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis源码——映射文件解析过程

1、映射文件解析解析入口

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

2、解析映射文件

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

3、Mapper接口绑定过程分析

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

4、处理未完成解析的节点

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis源码——SQL执行流程

1、SQL执行入口

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

2、查询语句的执行过程

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

3、更新语句的执行过程

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

4、SQL执行过程总结

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis源码——内置数据源

1、内置数据源初始化过程

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

2、UnpooledDataSource

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

3、PooledDataSource

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis源码——缓存机制

1、缓存类介绍

2、CacheKey

3、一级缓存

4、二级缓存

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

Mybatis源码——插件机制

  • 插件机制原理
  • 实现一个分页插件

硬核!阿里内部消化的Mybatis学习笔记,简短却精悍,全是重点

总结

我们总是喜欢瞻仰大厂的大神们,但实际上大神也不过凡人,与菜鸟程序员相比,也就多花了几分心思,如果你再不努力,差距也只会越来越大。实际上,作为程序员,丰富自己的知识储备,提升自己的知识深度和广度是很有必要的。扫码即可~

这篇关于绝了!想都不敢想会有这么全的MySQL学习笔记,从基础到进阶,简单但精悍,全是重点~的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/416314

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置