直面春招!最全MyBatis中XML映射文件标签分析+示例!感悟分享

news/2024/7/7 21:17:37

前言

关于为什么要有分布式锁这个东西,欢迎阅读我的zk分布式锁的实现,介绍了单机高并发、分布式高并发的解决方案:

用ZooKeeper实现分布式锁

这里再切入本例将使用的场景模拟:商品秒杀,或者说高并发下,对于商品库存扣减操作。我用一个SpringBoot小项目模拟一下该操作。

本例用到的技术栈:

  • SpringBoot
  • Redis
  • etcd

在正式肝代码之前,先来对etcd分布式锁实现的机制和原理做一个了解。

算法

  1. ⼏道常⻅的字符串算法题总结
  2. 最⻓公共前缀
  3. 回⽂串
  4. 两数相加
  5. 翻转链表
  6. 链表中倒数第k个节点
  7. 删除链表的倒数第N个节点
  8. 合并两个排序的链表
  9. 剑指offer部分编程题
  10. 跳台阶问题
  11. 变态跳台阶问题
  12. ⼆维数组查找
  13. 替换空格题⽬描述:
  14. 数值的整数次⽅
  15. 调整数组顺序使奇数位于偶数前⾯
  16. 链表中倒数第k个节点
  17. 反转链表
  18. 合并两个排序的链表
  19. ⽤两个栈实现队列
  20. 栈的压⼊,弹出序列

算法示例答案解析

数据结构

  1. Java 集合框架中的队列 Queue
  2. HashSet 和 TreeSet 底层数据结构
  3. List的常⻅实现类ArrayList 和 LinkedList 源码学习
  4. Map
  5. ⼆叉树
  6. 完全⼆叉树
  7. 满⼆叉树
  8. ⼆叉查找树(BST)
  9. 平衡⼆叉树(Self-balancing binary search tree)
  10. 红⿊树
  11. B-,B+,B*树
  12. LSM 树

数据结构答案解析

Redis

  1. 为什么要⽤ redis/为什么要⽤缓存
  2. 为什么要⽤ redis ⽽不⽤ map/guava 做缓存?
  3. redis 的线程模型
  4. redis 和 memcached 的区别
  5. redis 常⻅数据结构以及使⽤场景分析
  6. redis 设置过期时间
  7. redis 内存淘汰机制(MySQL⾥有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?)
  8. redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进⾏恢复)
  9. redis 事务
  10. 缓存雪崩和缓存穿透问题解决⽅案
  11. 如何解决 Redis 的并发竞争 Key 问题
  12. 如何保证缓存与数据库双写时的数据⼀致性?

Redis答案解析

MyBatis

  1. {}和${}的区别是什么?
  2. Xml 映射⽂件中,除了常⻅的 select|insert|updae|delete 标签之外,还有哪些标签?
  3. 最佳实践中,通常⼀个 Xml 映射⽂件,都会写⼀个 Dao 接⼝与之对应,请问,这个Dao接⼝的⼯作原理是什么?Dao接⼝⾥的⽅法,参数不同时,⽅法能重载吗?
  4. Mybatis 是如何进⾏分⻚的?分⻚插件的原理是什么?
  5. 简述 Mybatis 的插件运⾏原理,以及如何编写⼀个插件。
  6. Mybatis 执⾏批量插⼊,能返回数据库主键列表吗?
  7. Mybatis 动态 sql 是做什么的?都有哪些动态 sql?能简述⼀下动态 sql 的执⾏原理不?
  8. Mybatis 是如何将 sql 执⾏结果封装为⽬标对象并返回的?都有哪些映射形式?
  9. Mybatis 能执⾏⼀对⼀、⼀对多的关联查询吗?都有哪些实现⽅式,以及它们之间的区别。
  10. Mybatis 是否⽀持延迟加载?如果⽀持,它的实现原理是什么?
  11. Mybatis 的 Xml 映射⽂件中,不同的 Xml 映射⽂件,id 是否可以重复?
  12. Mybatis 中如何执⾏批处理?
  13. Mybatis 都有哪些 Executor 执⾏器?它们之间的区别是什么?
  14. Mybatis 中如何指定使⽤哪⼀种 Executor 执⾏器?
  15. Mybatis 是否可以映射 Enum 枚举类?
  16. Mybatis 映射⽂件中,如果 A 标签通过 include 引⽤了 B 标签的内容,请问,B 标签能否定义在 A 标签的后⾯,还是说必须定义在 A 标签的前⾯?
  17. 简述 Mybatis 的 Xml 映射⽂件和 Mybatis 内部数据结构之间的映射关系?
  18. 为什么说 Mybatis 是半⾃动 ORM 映射⼯具?它与全⾃动的区别在哪⾥?

MyBatis答案解析

总目录展示

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

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

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

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


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

由于内容太多,这里只截取部分的内容。需要这份《高并发秒杀顶级教程》的小伙伴,麻烦各位帮忙点赞分享支持一下(可以帮助更多的人看到哟!)
35098)]

[外链图片转存中…(img-xekH511d-1618888935098)]

由于内容太多,这里只截取部分的内容。需要这份《高并发秒杀顶级教程》的小伙伴,麻烦各位帮忙点赞分享支持一下(可以帮助更多的人看到哟!)


http://www.niftyadmin.cn/n/3647637.html

相关文章

栈的弹出函数pop()实现方案探讨

我想就上面的你说的3、4两条谈谈。STL的确是没有返回两个参数,甚至没有返回参数。std::stack::pop方法的声明形式是void pop()。也许各个版本有所不同,但SGI STL和STLport是这样的。作为使用最广泛的两种STL实现,我们完全可以认为这是业界认为…

想搞清楚ZooKeepe?助你面试一臂之力,含泪整理面经

接口概述: 接口是Java语言中的一种引用类型,是方法的"集合",所以接口的内部主要就是定义方法,包含常量,抽象方法(JDK 7及以前),额外增加默认方法和静态方法(JDK 8),额外增…

从实例重温工厂模式和单件模式

本文由恋花蝶最初发表于:http://blog.csdn.net/lanphaday,你可以在保持文章完整和保留本声明的情况下转帖、分发和印刷等。http://community.csdn.net/Expert/topic/4892/4892570.xml?temp.8727381今天一个好朋友发了上面这个贴,并邀我过去看…

想自学Java的速来!MySQL索引为何选择B+树?复习指南

前言 又到一年金九银十之际。 Java作为目前用户最多,使用范围最广的软件开发技术之一。 Java的技术体系主要由支撑Java程序运行的虚拟机,提供各开发领域接口支持的Java,Java编程语言及许多第三方Jvav框架构成。 其中,以Java的虚拟器为今天的着…

以讹传讹的小故事大道理

本文由恋花蝶最初发表于http://blog.csdn.net/lanphaday,可以转载、印刷等,但不可用于商业用途。并敬请保留本文完整,及包含本声明。昨天在公司内网看到同事贴出下面的这个小故事,终于是忍不住要反驳一下,就写了下次的…

成功入职字节跳动!只用了几百行代码写的百度搜索引擎,先收藏了

前言 MySQL 是最流行的关系型数据库管理系统(RDBMS)之一。 MySQL作为一个关系型数据库管理系统,因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下,MySQL是管理内容最好的选择。虽然功能未必很强大,但因为它…

基本A*算法python实现

本文由恋花蝶发表于http://blog.csdn.net/lanphaday,可以在保证全文完整的前提下任意形式自由传播,但必须保留本声明,违反必究。最近因为一个任务要用到A*算法,就用C实现了一份。不过只是用A*来检测从A点到B点有无通路&#xff0c…

Java面试java基础,锁机制(本地锁+分布式锁)超全分析!已开源

前言 微架构的出现,很好地适应了这个时代对快速发展变化的要求。它不再提倡一体化的项目设计,而是对项目进行有效的“业务区”(可以简单理解为不同的子系统〉划分,并利用合理的技术对业务性能做出提升和改善,同时又极大地简化了配…