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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 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/

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
MySQL分区与分表:优化性能与提升可扩展性
本文深入探讨了MySQL数据库中的分区与分表策略,通过详细的代码示例,解释了分区的概念与用途、不同的分区类型以及创建分区表的步骤。同时,文章还介绍了分表的概念、策略和实际操作方法,以代码演示展示了如何创建分表、插入数据以及查询数据。分区和分表作为优化数据库性能和提升可扩展性的关键手段,通过本文的阐述,读者将能够深入了解如何根据数据特点选择合适的分区方式,以及如何灵活地处理大量数据,提高查询和维护效率。这些技术将为数据库设计和优化提供有力支持,确保在大数据场景下能够高效地管理和查询数据。
2051 0
Mysql可扩展性
<div class="markdown_views"> <p>可扩展性。 即通过增加资源提升整个系统吞吐量的能力</p> <p>一般会有如下的角度影响负载:</p> <ul> <li>数据量</li> <li>用户量 更多的用户,意味着更多的数据,更复杂的查询,更多的事务</li> <li>用户活跃度 容易造成热点</li> <li>相关数据集的大小 即关联数据,
2621 0
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
从 MySQL 到时序数据库 TDengine:Zendure 如何实现高效储能数据管理?
TDengine 助力广州疆海科技有限公司高效完成储能业务的数据分析任务,轻松应对海量功率、电能及输入输出数据的实时统计与分析,并以接近 1 : 20 的数据文件压缩率大幅降低存储成本。此外,taosX 强大的 transform 功能帮助用户完成原始数据的清洗和结构优化,而其零代码迁移能力更实现了历史数据从 TDengine OSS 与 MySQL 到 TDengine 企业版的平滑迁移,全面提升了企业的数据管理效率。本文将详细解读这一实践案例。
33 0
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
166 82
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
MySQL生产环境迁移至YashanDB数据库深度体验
这篇文章是作者将 MySQL 生产环境迁移至 YashanDB 数据库的深度体验。介绍了 YashanDB 迁移平台 YMP 的产品相关信息、安装步骤、迁移中遇到的各种兼容问题及解决方案,最后总结了迁移体验,包括工具部署和操作特点,也指出功能有优化空间及暂不支持的部分,期待其不断优化。
云数据库:从零到一,构建高可用MySQL集群
在互联网时代,数据成为企业核心资产,传统单机数据库难以满足高并发、高可用需求。云数据库通过弹性扩展、分布式架构等优势解决了这些问题,但也面临数据安全和性能优化挑战。本文介绍了如何从零开始构建高可用MySQL集群,涵盖选择云服务提供商、创建实例、配置高可用架构、数据备份恢复及性能优化等内容,并通过电商平台案例展示了具体应用。
数据库数据恢复——MySQL简介和数据恢复案例
MySQL数据库数据恢复环境&故障: 本地服务器,安装的windows server操作系统。 操作系统上部署MySQL单实例,引擎类型为innodb,表空间类型为独立表空间。该MySQL数据库没有备份,未开启binlog。 人为误操作,在用Delete命令删除数据时未添加where子句进行筛选导致全表数据被删除,删除后未对该表进行任何操作。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等