快速提升MySQL可扩展性的五大绝招

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

快速提升MySQL可扩展性的五大绝招

我对抽象类和接口的理解

今天公司组织培训。讲解到抽象类和接口这里的时候。好像有同事不太明白。(请允许我自作多情一下!)

  鉴于我自己对这部分也不是掌握的很透彻。所以发个博文上来,一是记录一下。二是希望还不明白的朋友在阅读完本文之后能有个了解。

  新手,如有不当之处,请多多包涵!

  MSDN:抽象类是从子类发现了公共的东西,泛化(也可以说把公共的东西单独提取出来)出父类,然后子类继承父类,而接口是根本不知道子类的存在,方法如何实现还不确定,预先定义的

  有一个人,他叫王麻子,那年,他生了个儿子,起名叫 王三。这个时候用程序来描述就是他和他老婆创建了一个对象 ,代码如下:

public class WangSan
    {
        string FirstName;
        string Sex;
        void CanDo()
        {
            Console.WriteLine("我是王三,我会画画");
        }
    }

  王三有 姓、性别、和一个能力,他会画画。

  又过了一年,王麻子和他老婆又生了个孩子,起名叫 王四,用程序来说,他们俩又创建了一个对象

public class WangSi
    {
        string FirstName;
        string Sex;
        void CanDo()
        {
            Console.WriteLine("我是王四,我会唱歌");
        }
    }

  王四也有 姓、性别和一个能力,他会唱歌

  假如一下。假如他们是印度人,对计划生育没什么限制,他们每隔几年都会再生个孩子出来。这样的话。如果要用程序来描述起来岂不是很麻烦,所以这个时候我们应该考虑对代码进行重构,提取共同的部分,也就是姓名、性别和一个能力

  如下:

public abstract class Son
    {
        protected string FirstName;
        protected string Sex;
    }

  因为他们都是王麻子的孩子,咱们假设一下,假设由于他们都是王麻子的孩子,所以他们必须 姓王、有性别,所以这个 基类 Son 就必须声明为  abstract 的(创建就为被继承)。就是说凡是 王麻子的孩子,都必须继承自 Son 这个基类,因为他们都有王麻子的一些特性和自己的特性,

  比如:

public class WangSan:Son
    {
    }

  我们不必在 WangSan 这个类中写任何代码,因为他是王麻子的孩子,所以他有 姓 和 性别。。在New WangSan 这个对象的时候。他就自动的有了 FirstName 和 Sex。这些属性。

又假如,由于王麻子是个全能人才。所以他的孩子必须会一项技术,比如游泳或者 唱歌。这个时候 基类就可以修改一下:

public abstract class Son
    {
       protected string Name;
       protected string Sex;
        /// <summary>
        /// 抽象类中的抽象方法,在子类中必须自行实现
        /// </summary>
        public abstract void CanDO();
    }

  添加了 CanDo 的抽象方法。 这样 当 王三 这个对象一被创建,他就必须继承 Son 这个类(他必须是王麻子的儿子,莫非两口子生的孩子是别人的??)...而又由于Son 中有个抽象的方法 CanDo. 所以。王三 他必须 得有一项技术。如果不实现 CanDo .编译不通过(你不实现,就不能说明你是我孩子,以后我对你不好!)

public class WangSan:Son
    {
        public override void CanDO()
        {
            Console.WriteLine("我是王三,王麻子的孩子,我必须有一个擅长,那我选择唱歌");
        }
    }

  这样。王三也必须会一项长处了!!

  王四也是一样。只要他是 王麻子的儿子。他就必须实现 CanDo 方法,并且有FirstName 和 Sex属性

  又假如有一天,王麻子偷师学艺,学会水上漂。但是他不知道谁愿意学,又不想强迫孩子们。所以他让孩子们自己决定。他定义了一个接口(发布了一个规范) IShuiShangPiao

interface IShuiShangPiao {
        void CanFly();
    }

  谁想学。就来我这里报道。结果王武想学。所以王武来报道了(程序解释就是王武实现这个接口)

public class WangWU : Son, IShuiShangPiao
    {
        public override void CanDO()
        {
            throw new NotImplementedException();
        }
        /// <summary>
        /// 实现接口(报道),老爸就教我水上漂
        /// </summary>
        public void CanFly()
        {
            throw new NotImplementedException();
        }
    }

  回到我们软件开发当中,假设以上类是我们程序中实现的一项功能,假如某一天,我们发现(或者客户要求):凡是王麻子的孩子都必须会英语,这个时候,我们就仅仅只需要在 Son 这个类中 增加一个会说英语的方法。他的孩子们就都会说英语了。如果不采用继承的话。假设王麻子有1万个孩子,那就得修改一万个类,很累。。。。

  以上就是我个人针对 抽象类和 接口的理解,如有不当之处,敬请提出!

  程序需要慢慢重构,这个我当时理解起来也非常不容易。多练习,多思考就会豁然开朗!

  但是切记,千万不要为了设计而设计。造成过度设计会很糟糕的。。。就好像我们设计数据库,虽然有3大范式,但是有时候业务迫使我们不得不违背。。。。

  以上!

  希望对这部分不明白的朋友通过本文能对这部分知识有个进一步的了解。同时希望各位的技术一天牛比一天!!


本文出自seven的测试人生公众号最新内容请见作者的GitHub页:http://qaseven.github.io/

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
关系型数据库 MySQL 大数据
MySQL分区与分表:优化性能与提升可扩展性
本文深入探讨了MySQL数据库中的分区与分表策略,通过详细的代码示例,解释了分区的概念与用途、不同的分区类型以及创建分区表的步骤。同时,文章还介绍了分表的概念、策略和实际操作方法,以代码演示展示了如何创建分表、插入数据以及查询数据。分区和分表作为优化数据库性能和提升可扩展性的关键手段,通过本文的阐述,读者将能够深入了解如何根据数据特点选择合适的分区方式,以及如何灵活地处理大量数据,提高查询和维护效率。这些技术将为数据库设计和优化提供有力支持,确保在大数据场景下能够高效地管理和查询数据。
1084 0
|
缓存 网络协议 NoSQL
Mysql可扩展性
<div class="markdown_views"> <p>可扩展性。 即通过增加资源提升整个系统吞吐量的能力</p> <p>一般会有如下的角度影响负载:</p> <ul> <li>数据量</li> <li>用户量 更多的用户,意味着更多的数据,更复杂的查询,更多的事务</li> <li>用户活跃度 容易造成热点</li> <li>相关数据集的大小 即关联数据,
2530 0
|
18天前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
20天前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
160 11
|
2月前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!点击阅读原文完成实验就可获得一本日历哦~
|
2月前
|
关系型数据库 MySQL 数据库
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
|
15天前
|
存储 SQL 关系型数据库
MySQL的安装&数据库的简单操作
本文介绍了数据库的基本概念及MySQL的安装配置。首先解释了数据库、数据库管理系统和SQL的概念,接着详细描述了MySQL的安装步骤及其全局配置文件my.ini的调整方法。文章还介绍了如何启动MySQL服务,包括配置环境变量和使用命令行的方法。最后,详细说明了数据库的各种操作,如创建、选择和删除数据库的SQL语句,并提供了实际操作示例。
58 13
MySQL的安装&数据库的简单操作
|
21天前
|
存储 SQL 关系型数据库
一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案
MySQL如何进行分库分表、数据迁移?从相关概念、使用场景、拆分方式、分表字段选择、数据一致性校验等角度阐述MySQL数据库的分库分表方案。
一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案
|
3天前
|
关系型数据库 Unix MySQL
MySQL是一种关系型数据库管理系统
MySQL是一种关系型数据库管理系统
11 2
下一篇
无影云桌面