版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、咕泡学院(每天 20:30 腾讯课堂公开课)今日课程:基于 SpringJDBC 实现ORM 及分库分表不只做咕泡学咕泡学咕泡学咕泡学打开腾课程安排 一、什么是 ORM 对象关系映射(Object Relational Mapping) 二、为什么要使用 ORM 框架 ORM 框架有哪些?Hibernate 全自动、MyBatis半自动对比(手自一体)、SpringJDBC 纯手动档(设计思想)Hibernate 的数据库移植性远大于 MybatisHibernate 有完整的日志系统,Mybatis 只有基本的记录功能SQL 优化上,Mybatis 更方便,可控性较强。SSM /SSH一个
2、S 搞定(Spring 生态系统SpringMVC/SpringJDBC/AOP/IOC/SpringData/SpringCloud/Spring Boot)三、代码演示 ORM 实现原理 1、了解 ResultSet 的 getMetaData()方法和getColumnCount()2、利用反射机制扫描出实体中的注解,将实体类名和表名,属性名和字段名关联3、从结果集中取值并封装实体对象四、为什么要分库、分表 数据库中的数据量不一定是可控的,在未进行分库分表的情况下,随着时间和业务的发展,库中的表会越来越多,表中的数据量也会越来越大,相应地,数据操作,增删改查的开销也会越来越大;另外,由于
3、无法进行分布式式部署,而一台服务器的资源(CPU、磁盘、内存、IO 等)是有限的,最终数据库所能承载的数据量、数据处理能力都将遭遇瓶颈。五、分享企业内部框架、设计 ORM 及分库、分表操作 API 1、单表操作实现 NoSql2、如何设计分库 API,利用 ThreadLocal 动态切换数据源3、如何设计分表 API,自定义分表算法,动态计算表名4、如何设计读写分离 API,数据库主从实现读写分离5、设计 QueryRule 类,NoSql 的重要中间件6、设计常用的 ORM 操作 API,增、删、改、查六、浅谈常用分库分表规则 设计表的时候需要确定此表按照什么样的规则进行分库分表。例如,当
4、有新用户时,程序得确定将此用户信息添加到哪个表中;同理,当登录的时候我们得通过用户的账号找到数据库中对应的记录,所有的这些都需要按照某一规则进行。路由通过分库分表规则查找到对应的表和库的过程。如分库分表的规则是 user_id mod 4 的方式,当用户新注册了一个账号,账号 id 的 123,我们可以通过 id mod 4 的方式确定此账号应该保存到 User_0003 表中。当用户 123 登录的时候,我们通过 123 mod4 后确定记录在 User_0003 中。Range(范围)这种模式允许将数据划分不同范围。例如可以将一个表通过年份划分成若干个分区。Hash(哈希)这中模式允许通过
5、对表的一个或多个列的 HashKey 进行计算,最后通过这个 Hash 码不同数值对应的数据区域进行分区。例如可以建立一个对表主键进行分区的表。Key(键值)-上面 Hash 模式的一种延伸,这里的 Hash Key是 MySQL 系统产生的。List(预定义列表)这种模式允许系统通过预定义的列表的值来对数据进行分割。七、分库分表产生的问题,及注意事项 1.分库分表维度的问题假如用户购买了商品,需要将交易记录保存取来,如果按照用户的纬度分表,则每个用户的交易记录都保存在同一表中,所以很快很方便的查找到某用户的购买情况,但是某商品被购买的情况则很有可能分布在多张表中,查找起来比较麻烦。反之,按照
6、商品维度分表,可以很方便的查找到此商品的购买情况,但要查找到买人的交易记录比较麻烦。所以常见的解决方式有:a.通过扫表的方式解决,此方法基本不可能,效率太低了。b.记录两份数据,一份按照用户纬度分表,一份按照商品维度分表。c.通过搜索引擎解决,但如果实时性要求很高,又得关系到实时搜索(聚合查询)。2.联合查询的问题联合查询基本不可能,因为关联的表有可能不在同一数据库中。3.避免跨库事务避免在一个事务中修改 db0 中的表的时候同时修改 db1 中的表,一个是操作起来更复杂,效率也会有一定影响。4.尽量把同一组数据放到同一 DB 服务器上。八、总结 1、ORM 优、缺点优点:1.隐藏了数据访问细
7、节,“封闭”的通用数据库交互,ORM的核心。他使得我们的通用数据库交互变得简单易行,并且完全不用考虑该死的 SQL 语句。快速开发。2.ORM 使我们构造固化数据结构变得简单易行。缺点:1.无可避免的,自动化意味着映射和关联管理,代价是牺牲性能(早期,这是所有不喜欢 ORM 人的共同点)。现在的各种ORM 框架都在尝试使用各种方法来减轻这块(LazyLoad,Cache),效果还是很显著的。2.面向对象的查询语言(X-QL)作为一种数据库与对象之间的过渡,虽然隐藏了数据层面的业务抽象,但并不能完全的屏蔽掉数据库层的设计,并且无疑将增加学习成本。3.对于复杂查询,ORM 仍然力不从心。虽然可以实现,但是不值得。世上没有驴是不吃草的(又想
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 景德镇学院《中国对外贸易》2025-2026学年期末试卷
- 福建技术师范学院《解剖学基础》2025-2026学年期末试卷
- 阳泉职业技术学院《管理系统中计算机应用》2025-2026学年期末试卷
- 2026年连云港市新浦区社区工作者招聘笔试参考题库及答案解析
- 2026年三明市三元区社区工作者招聘考试备考题库及答案解析
- 黑客与人工智能威胁
- 2026年陕西省铜川市城管协管招聘笔试备考题库及答案解析
- 2026年无锡市惠山区社区工作者招聘考试参考试题及答案解析
- 2026年荆州市荆州区社区工作者招聘考试参考试题及答案解析
- 2026年江苏省苏州市社区工作者招聘考试模拟试题及答案解析
- 浙江华帝纺织印染有限公司年产3000万米高档印染面料技改项目环境影响报告
- 溺水自救与施救课件
- 无机及分析化学说课
- 家庭装修施工合同
- 三角形的认识(强震球)
- 2021年湖南省衡阳市国家公务员公共基础知识真题二卷(含答案)
- GB/T 12350-2022小功率电动机的安全要求
- GB/T 10045-2018非合金钢及细晶粒钢药芯焊丝
- 2.5《给船装上动力》教学课件
- GA/T 832-2014道路交通安全违法行为图像取证技术规范
- 爱立信专区-基站rbs6201产品手册
评论
0/150
提交评论