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

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

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
关系型数据库 MySQL 大数据
MySQL分区与分表:优化性能与提升可扩展性
本文深入探讨了MySQL数据库中的分区与分表策略,通过详细的代码示例,解释了分区的概念与用途、不同的分区类型以及创建分区表的步骤。同时,文章还介绍了分表的概念、策略和实际操作方法,以代码演示展示了如何创建分表、插入数据以及查询数据。分区和分表作为优化数据库性能和提升可扩展性的关键手段,通过本文的阐述,读者将能够深入了解如何根据数据特点选择合适的分区方式,以及如何灵活地处理大量数据,提高查询和维护效率。这些技术将为数据库设计和优化提供有力支持,确保在大数据场景下能够高效地管理和查询数据。
1379 0
|
缓存 网络协议 NoSQL
Mysql可扩展性
<div class="markdown_views"> <p>可扩展性。 即通过增加资源提升整个系统吞吐量的能力</p> <p>一般会有如下的角度影响负载:</p> <ul> <li>数据量</li> <li>用户量 更多的用户,意味着更多的数据,更复杂的查询,更多的事务</li> <li>用户活跃度 容易造成热点</li> <li>相关数据集的大小 即关联数据,
2567 0
|
8天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
23 4
|
6天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
19 1
|
1月前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
61 3
Mysql(4)—数据库索引
|
15天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
81 1
|
17天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
59 2
|
20天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
80 4
|
3天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
27 0