近期计划写一套书目,也就是关于mysql的优化的。那么首先在博客上写写,然后整理成pdf的文档的形式,当然也期待各位的关注了。对于mysql的优化是一个比較大的话题。可优化的地方也非常多,大致想了一下,能够从这些地方下手。

首先就是硬件层次,包含选择合适的操作系统、选择合适的硬件,然后就是源码层次,只是尽管mysql是开源的,可是可以改动其源码的公司尽管不少,可是也没有那么多,可是我们可以选择更加合适的编译器又一次编译其源码,然后就是设计到表的设计。也就数据库建模。

其次能够考虑使用一些其它技术,比方读写分离和分表技术,或者使用集群技术,这要求我们从总体上去构架。对于详细的内容,我们能够採用设置索引、优化sql查询语句、定期表修复、使用存储过程等等。

这里我们先说说数据库建模这部分,这部分往往和和业务逻辑有关系,通常来说新手都喜欢死扣第三范式或者BC范式。假设更要求完美,可能会死扣第五范式,事实上高手也都是这么一步步过来的,那么我们先介绍一下什么是第三范式。

第一范式就是对属性的原子性约束。也就是说表的列具有原子性,不能再次切割。它的约束性真的非常低。仅仅要数据库是关系型数据库,就会自己主动满足第一范式了,那么哪些可能会不满足第一范式呢?假设我们存储了一个集合。存储了一个数组。那么这就不满足第一范式了,可是对于关系型数据库。不可能出现这样的情况,我们无法向里面存储一个数组。注意,这里说的是存储了一个集合。而不是集合中的元素。

第二范式就是属性全然依赖于主键,举个样例,增加我们创建一个People表。它里面能够写一个字段是身份证号。那么由于每一个人的身份证号都不是不反复的,这个人的信息也会由这个人的身份证号唯一决定,这就能够能够理解为一个主键,这里的身份证号是主键,可是姓名并非主键。由于重名的情况还是挺多的。它的目的是为了防止数据的反复,因此我们使用一个主键来唯一的标识一条记录。

须要注意的是。主键并不一定必须是一个字段,比方说有时候两个信息才干确定一条记录,比方在一个目录以下的文件名称和后缀名这两个才干确定一个唯一的文件名称,我们分开来存放信息的话,这两个字段就构成了它的主键。值得注意的是,我们通经常使用一个数字类型的自增的id来作为主键。但它不是必须的。

第三范式的要求就更加苛刻了,它要求表中不要有冗余数据,那它的规范就是说:不论什么非主键的属性都必须依赖于主键,可是不能传递依赖于主键。

举个超经典的样例,这也是我在学习第三范式的时候的样例。由于它太经典了,我可能一辈子都忘记不了。比方说我建立了一个表。它的字段信息例如以下:(学号。学生姓名,学生所在系名。学生所在系的地址),猛一看这个表也没什么问题。可是它会产生冗余信息。那就是学生所在系的地址这一个属性也是由学号唯一确定的,可是它不是直接依赖的。它是传递依赖的,它直接依赖与系名,而不是学生的学号,因此,我们会发现,对于不同的学号,会导致存储非常多一样的系名,这就是所谓的冗余信息。

那么我们怎么改动呢,答案就是分表。注意。我们还必须遵循第二范式,我们能够添加一个系的编号这么一个字段。即第一个表信息(学号,学生姓名,所在系编号)。第二个表(系编号。系名,系的地址),这么一来,我们就不会存储冗余信息了,这就是第三范式所带来的效果。

除了第三范式之外,另一个也非常重要,叫做BC范式,也就是著名的巴斯-科德范式,它的要求是什么呢?它是对主键的要求,也就是主码,它要求,主码的不论什么一个真自己都不能唯一的确定这个主码,什么意思。比方说我把学生的身份证号和学号这两个合起来 设计为主键,它并不违反第三范式,可是它违反了BC范式。原因何在呢?由于在一个学校里,不论什么两个学生的身份证号和学号都不同样,也就是说,我们使用学号作为主键或者身份证号作为主键都能够,可是使用这两个一起作为主键,不是必需。

我不知道读者是否晕了,大体思路就是这样。事实上这些范式都是人做出来的。也不难理解。我这里并没有引入太多的逻辑符合和专业术语。算是用比較寻常的语言来叙述,也是希望更好理解,假设您有什么问题,能够在以下留言给我。

辛星让mysql跑的更快第一节之优化的方向和数据库建模的更多相关文章

  1. 让MySQL数据库跑的更快的7个优化建议!

    随着容量和负载的增加,MySQL 的性能会日趋缓慢.这里有七点建议能够保证 MySQL 的平稳运行. 性能是我们衡量应用的一种方式,而应用性能的一项指标就是用户体验,也就是平时我们常说的:“用户需要等 ...

  2. 让DB2跑得更快——DB2内部解析与性能优化

    让DB2跑得更快——DB2内部解析与性能优化 (DB2数据库领域的精彩强音,DB2技巧精髓的热心分享,资深数据库专家牛新庄.干毅民.成孜论.唐志刚联袂推荐!)  洪烨著 2013年10月出版 定价:7 ...

  3. UOJ 【UR #5】怎样跑得更快

    [UOJ#62]怎样跑得更快 题面 这个题让人有高斯消元的冲动,但肯定是不行的. 这个题算是莫比乌斯反演的一个非常巧妙的应用(不看题解不会做). 套路1: 因为\(b(i)\)能表达成一系列\(x(i ...

  4. 【UOJ#62】【UR #5】怎样跑得更快(莫比乌斯反演)

    [UOJ#62][UR #5]怎样跑得更快(莫比乌斯反演) 题面 UOJ 题解 众所周知,\(lcm(i,j)=\frac{ij}{gcd(i,j)}\),于是原式就变成了: \[\sum_{j=1} ...

  5. 「UR#5」怎样跑得更快

    「UR#5」怎样跑得更快 膜这个您就会了 下面是复读机mangoyang 我们要求 \[ \sum_{j=1}^n \gcd(i,j)^{c-d} j^d x_j=\frac{b_i}{i^d} \] ...

  6. 面试官:如何写出让 CPU 跑得更快的代码?

    前言 代码都是由 CPU 跑起来的,我们代码写的好与坏就决定了 CPU 的执行效率,特别是在编写计算密集型的程序,更要注重 CPU 的执行效率,否则将会大大影响系统性能. CPU 内部嵌入了 CPU ...

  7. 辛星解读mysql的用户管理

    可能做开发的多半不太关注这方面,可是要说到做运维.那就不能不关注了.由于我们都知道,root的权限太大了.不是随便能用的.我们平时最好用一些比較低的权限的用户.这样会让我们的安全性大大提高,也能防止我 ...

  8. [翻译] 5点建议,让iOS程序跑得更快

      [文章原地址]http://mobile.tutsplus.com/tutorials/iphone/ios-quick-tip-5-tips-to-increase-app-performanc ...

  9. 让你的 Node.js 应用跑得更快的 10 个技巧(转)

    Node.js 受益于它的事件驱动和异步的特征,已经很快了.但是,在现代网络中只是快是不行的.如果你打算用 Node.js 开发你的下一个Web 应用的话,那么你就应该无所不用其极,让你的应用更快,异 ...

随机推荐

  1. [BZOJ 1926] 粟粟的书架

    BZOJ 传送门 Luogu 传送门 BZOJ的sillyB评测机各种无故CE,只好去Luogu上A了o(╯□╰)o Solution: 从数据范围可以发现,这其实是2道题: (1)一个$R*C$的矩 ...

  2. [BZOJ2226]LCMSum

    转化一下,$\sum\limits_{i=1}^n[i,n]=n\sum\limits_{i=1}^n\dfrac i{(i,n)}$ 枚举$d=(i,n)$,上式变为$n\sum\limits_{d ...

  3. 【R笔记】给R加个编译器——notepad++

    R的日记-给R加个编译器 转载▼ R是一款强大免费且开源的统计分析软件,这是R的长处,可也是其“缺陷”的根源:不似商业软件那样user-friendly.记得初学R时,给我留下最深印象的不是其功能的强 ...

  4. [读书笔记]iOS 7 UI设计 对比度

    好久没写随笔了,最近在读<iOS 7 byTutorials>,很不错,推荐给大家. 每一个好的程序员也都是一个设计师,不懂设计的程序员不是好的CTO.哈哈,开个小玩笑. iOS 7设计的 ...

  5. iOS 调H5方法不执行没反应的坑

    调用H5的方法需要给H5传一些参数,参数中包括图片的base64字符串. 错误一: 图片转base64,后面参数不能随便写,正确做法如下 NSData *imageData = UIImageJPEG ...

  6. 网络采集软件核心技术剖析系列(3)---如何使用C#语言下载博文中的全部图片到本地并可以离线浏览

    一 本系列随笔概览及产生的背景 本系列开篇受到大家的热烈欢迎,这对博主是莫大的鼓励,此为本系列第三篇,希望大家继续支持,为我继续写作提供动力. 自己开发的豆约翰博客备份专家软件工具问世3年多以来,深受 ...

  7. zip压缩与解压文件夹或文件

    import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.File; import ...

  8. RedisTemplate SerializationFailedException: Failed to deserialize payload 异常解决

    问题描述: 使用RedisTemplate(spring-data-redis )进行redis操作的封装 , 现有一个incr的key , 当调用incr后返回值一切正常, 当对此key进行get调 ...

  9. 【spring boot】spring boot中使用定时任务配置

    spring boot中使用定时任务配置 =============================================================================== ...

  10. JAMon监控web工程方法的调用性能

    JAMon简介 JAMon的全名是:Java Application Monitor.它是一个小巧的,免费的,高性能的,线程安全的性能监测工具. 它可以用来测定系统的性能瓶颈,也可以用来监视用户和应用 ...