首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

数据库MySQL-设计原则

二、MYSQL数据库设计原则 1、核心原则 不在数据库做运算; cpu计算务必移至业务层; 控制列数量(字段少而精,字段数建议在20以内); 平衡范式与冗余(效率优先;往往牺牲范式) 拒绝3B(拒绝大sql...语句:big sql、拒绝大事务:big transaction、拒绝大批量:big batch); 2、字段类原则 用好数值类型(用合适的字段类型节约空间); 字符转化为数字(能转化的最好转化,同样节约空间...提高查询性能); 避免使用NULL字段(NULL字段很难查询优化、NULL字段的索引需要额外空间、NULL字段的复合索引无效); 少用text类型(尽量使用varchar代替text字段); 3、索引类原则...; 不在索引做列运算; innodb主键推荐使用自增列(主键建立聚簇索引,主键不应该被修改,字符串不应该做主键)(理解Innodb的索引保存结构就知道了); 不用外键(由程序保证约束); 4、sql类原则...trig/func(触发器、函数不用客户端程序取而代之); 不用select *(消耗cpu,io,内存,带宽,这种程序不具有扩展性); OR改写为IN(or的效率是n级别); OR改写为UNION(mysql

1.7K20

MySQL数据库系列之数据库设计原则

MySQL数据库设计原则: 1.一般情况下,应该尽量使用可以正确存储数据的最小数据类型。数据类型不一样,存储的执行效率也不一样。...2.尽量避免NULL值的时候,因为这样会增加数据库处理的开销。但是也要考虑实际情况,不要一味的为了避免空值而全部设置为not null,具体的设置情况要根据项目的具体业务来。...需要注意的是varchar定义的长度最好可以刚好够用,不然会照成资源的浪费,影响整体数据库的性能和存储空间。 4.能用整数标示,最好利用整数标示,因为这样开销最小,效率也是最高的。...6.在设计表和设计查询语言的时候就要主要尽量避免大规模的关联查询,因为这样会严重影响数据库的查询效率。 7.在设计数据库的时候要根据具体的业务设计出合理的数据库表和字段。...在不影响数据安全和数据冗余的情况下,可以适当的考虑混合范式的设计。 8.使用缓存表和汇总表能表进行数据库的查询优化。

2.4K100
您找到你想要的搜索结果了吗?
是的
没有找到

MYSQL数据库设计之字段选择原则

今天给大家介绍一下数据库设计过程中字段的选择原则,也就是什么时候用int、什么时候用varchar、什么时候用char等等之类的。...如果想要全面的了解的话,大家可以去看高性能MYSQL这一本书籍,里面有一章节介绍的特别全面,基本涉及MYSQL中全部的字段的介绍。...在数据库设计过程中我们要本着够用的原则,如果一味的把数据字段范围设为最大或者默认值的话,会导致存储空间大量的浪费。...在数据量特别大的情况下,这样的设计原理将会使数据库空间造成严重的浪费,也会对数据库的执行效率造成很大的影响。所以我们在做数据库设计的时候要谨慎再谨慎、小心再小心。...2.数据库设计过程中尽量使用int来作为字段类型,因为在所有的数据类型中int不管是存储空间还是执行速度方面都是最好的。

4K80

MySQL索引设计原则

MySQL索引的设计原则: 索引设计原则一: 针对sql语句中的where,order by,group by条件设计索引。...并且注意where,order by,group by后面跟的字段的顺序,是不是某个联合索引的最左侧字段开始的部分字段 索引设计原则二: 需要考虑字段基数的问题,一般建立索引尽量使用那些基数较大的字段,...索引设计原则三 尽量对那些字段类型较小的字段来设计索引。...对于前缀索引,仅仅包含部分字符到索引树中,where查询是可以使用的,但是order by和group by就用不上了 索引设计原则设计索引需要考虑到数据插入更新时索引树也会进而更新,以及主键一定要是自增的...避免数据稀疏造成频繁的页分裂,其次就是索引不要设计的太多,毕竟维护成本较高,也占用磁盘,还有就是插入的数据不是按照顺序来的,从而会导致某个索引树里的索引页自动分裂这就会很浪费时间 总结: 简单来说建立索引需要考虑的点主要一下几个方面

20320

数据库篇:mysql设计原则-三范式

前言 关系型数据库的表在设计时,我们常常需要考虑哪些业务字段应该放哪张表,字段是否应该拆分,表与表之间该怎么关联。那有没有相应的规范或者原则来指导我们去设计表呢?...数据库设计三范式;三范式主要是解决表之间的关联关系,和字段冗余问题 关注公众号,一起交流,微信搜一搜: 潜行前行 第一范式 列都是不可再分,第一范式的目标是确保每列的原子性,每列都是不可再分的最小数据单元...符合第一范式的设计 ? 第二范式 首先满足第一范式,并且表中非主键列不存在对主键不依赖或者部分依赖,确保每个列都和主键相关。...欢迎指正文中错误 参考文章 mysql 数据库设计三范式[1] Reference [1] mysql 数据库设计三范式: https://www.cnblogs.com/xiaozengzeng/

1.1K10

数据库设计原则

引言 本文小结了数据设计原则数据库设计对于数据库的可维护性、可扩展性至关重要,某些原则必须严格遵守; 数据库设计范式 第一范式:属性具有原子性,不可再分解,即不能表中有表; 第二范式:唯一性约束,每条记录有唯一标示...,所有的非主键字段均需依赖于主键字段; 第三范式:冗余性约束,非主键字段间不能相互依赖; 数据库设计原则 完整性: not null声明禁止插入空值; check子句限制属性域; 去冗余: 避免冗余属性...,冗余属性会带来数据不一致性; 学生选课系统中,老师可以开课、学生可以选课,数据库设计中,课程可以由课程编号和课程名称等确定; 如果现在维护两个表,一个表A存储课程信息(课程编号、名称、简介、学分、院系等...,降低性能; 如果性能成为主要矛盾,则上述原则也不绝对; 数据库命名原则 数据库的命名会直接影响到上层应用的名称,所以要和业务部门仔细讨论、慎重确定; 每个属性名在数据库中只有唯一的含义,number这个属性名可能表示电话号码或是房间号...至少保存3个月的系统访问日志; 数据库中的表可以有创建和更新时间戳,及所创建/修改行的用户标示; 不删除字段,而是打上一个被删除的标记; 版本化修改; 大型数据库设计 负载均衡; 读写分离; 分布式存储

68560

MySQL-性能优化-优化设计设计原则

MySQL性能优化目的 如何合理的设计数据库? 什么样的数据库设计才能给后期DBA优化提供基石? 数据库设计与程序设计的差异? ? 数据库设计早期优化 1....提高效率 数据库表开发流程 原型=>逐步完善(表的设计也是如此) 数据库种类 1....层级数据库(注册表) 如:Windows操作系统的核心就是一个注册表,由于配置项比较多,采用层级关系的数据存储 2. 关系型数据库 如:MySQL 3. 时序数据库 4....优化设计第三步 数据库优化策略 1、选择小的数据类型 2、单独设计主键,并考虑分布式扩展 3、外键设计 (重要,我们之前开发都是直接使用的弱外键来设置主外键关系,而实际项目中,如果要是删除了主键对应的记录后...在设计数据库的时候应当落实如下的原则 (一)降低对数据库功能的依赖(如在业务上使用了MySQL特性,且这个特性是只有MySQL存在的,对以后的数据库迁移会带来很大的麻烦) (二)定义实体关系的原则 牵涉到的实体

70720

MySQL 性能优化,优化设计设计原则解读

作者:秋日芒草 原文:https://my.oschina.net/qrmc/blog/1819509 MySQL性能优化的目的 如何合理的设计数据库?...什么样的数据库设计才能给后期DBA优化提供基石? 数据库设计与程序设计的差异? ? 数据库设计早期优化 1. 关系明确(理清表之间的关系,可以通过冗余的方式提高效率) 2....层级数据库(注册表) 如:Windows操作系统的核心就是一个注册表,由于配置项比较多,采用层级关系的数据存储 2. 关系型数据库 如:MySQL 3. 时序数据库 4....,帐户变动或业务处理的中间值 在设计数据库的时候应当落实如下的原则 (一)降低对数据库功能的依赖(如在业务上使用了MySQL特性,且这个特性是只有MySQL存在的,对以后的数据库迁移会带来很大的麻烦)...(二)定义实体关系的原则 牵涉到的实体 识别出关系所涉及的所有实体。

79531

数据库设计原则有哪些_数据库原则

数据库设计是程序开发的核心部分,标准的数据库设计原则和步骤能有效提高开发进度和效率。...5) 定义标准的对象命名规范   数据库各种对象的命名必须规范。  2. 表和字段的设计数据库逻辑设计)   表设计原则   1) 标准化和规范化   数据的标准化有助于消除数据库中的数据冗余。...简单来说,遵守3NF 标准的数据库的表设计原则是:“One Fact in One Place”即某个表只包括其本身基本的属性,当不是它们本身所具有的属性时需进行分解。表之间的关系通过外键相连接。...在关系数据库里不要单独删除某一行;最好采用清除数据程序而且要仔细维护索引整体性。  3. 选择键和索引(数据库逻辑设计)   键选择原则:   1) 键设计4 原则 为关联字段创建外键。   ...索引使用原则:   索引是从数据库中获取数据的最高效方式之一。95%的数据库性能问题都可以采用索引技术得到解决。

3.7K30

设计原则——开闭原则

什么是开闭原则? 在设计一个模块的时候,应当使这个模块可以在不被修改的前提下被扩展,即应当可以在不必修改源代码的情况下改变这个模块的行为。 如何运用开闭原则?...开闭原则解决问题的关键在于抽象化,把系统所有可能的行为抽象成一个抽象底层,这个抽象底层规定出所有的具体实现必须提供的方法的特征,给系统定义出一个一劳永逸,不再修改的抽象设计,此设计允许有无穷尽的行为在实现层被实现...在JAVA中可以定义一个或多个抽象Java类或Java接口,规定出所有的具体类必须提供的方法的特征作为系统设计的抽象层。...作为系统设计的抽象层,要预见所有可能的扩展,因此在任何扩展情况下系统抽象底层不需要修改。同时,由于抽象层导出一个或多个新的具体类可以改变系统的行为,因此系统的设计对扩展是开放的。...遵守开闭原则进行如下改变 打折类: public class OffNovelBook extends NovelBook { public OffNovelBook(String name

5600

mysql 备份数据库原则_MySQL数据库备份方法说明

MySQL数据库备份方法说明 更新时间:2007年07月29日 17:52:57 作者: 在数据库表丢失或损坏的情况下,备份你的数据库是很重要的。...不管你使用哪种备份方法,如果你需要恢复数据库,有几个原则应该遵守,以确保最好的结果: 定期实施备份。建立一个计划并严格遵守。 让服务器执行更新日志。当你在崩溃后需要恢复数据时,更新日志将帮助你。...换句话说,mysqldump产生的输出可在以后用作mysql的输入来重建数据库。...如果你倒出一个数据库以便能把数据库转移到另一个服务器,你甚至不必创建备份文件。要保证数据库存在于另一台主机,然后用管道倾倒数据库,这样mysql能直接读取mysqldump的输出。...对于任何可适用的更新日志,将它们作为mysql的输入。指定–one-database选项使得mysql只执行你有兴趣恢复的数据库的查询。

11.4K10

设计原则

类应该对扩展开发,对修改关闭 依赖倒置原则 要依赖抽象,不要依赖具体类 依赖倒置,倒置在哪? 在依赖倒置原则中的倒置指的是和一般的OO设计的思考方式完全相反。...如果说设计一个比萨店,我们应该从上往下思考,先要有一个比萨店,然后比萨点根据要求生产出具体类型的比萨。...(具体方式可以是简单工厂,也可以是工厂方法模式) 本来的设计方式: ? 依赖倒置的设计方式: ? 最少知识原则 不要让太多类耦合在一起,免得修改系统的一部分,会影响到另外一部分。 ? ?...内聚 当来一个类或者一个模块被设计成只支持一组相关功能的时候,我们说它具有高内聚。反之,当被设计成支持一组不相关的功能时,我们说它具有低内聚。...里氏替换原则为继承定义的规范: 子类必须完全实现父类的方法 子类可以有自己的新方法、新属性

50940

设计原则:面向对象设计原则详解

而在面向对象的设计里面,可维护性复用都是以面向对象设计原则为基础的,这些设计原则首先都是复用的原则。遵循这些设计原则可以有效地提高系统的复用性,同时提高系统的可维护性。...面向对象设计原则设计模式也是对系统进行合理重构的指导方针。...3、接口隔离和单一职责的区别: 范围区别:单一职责原则是针对模块、类、接口的设计,接口隔离原则相对单一职责更侧重接口的设计。...2、原则分析: 1)如果说开闭原则是面向对象设计的目标,依赖倒转原则是到达面向设计"开闭"原则的手段..如果要达到最好的"开闭"原则,就要尽量的遵守依赖倒转原则....例子:某系统提供一个数据转换模块,可以将来自不同数据源的数据转换成多种格式,如可以转换来自数据库的数据(DatabaseSource)、也可以转换来自文本文件的数据(TextSource),转换后的格式可以是

1.8K30

设计原则

这种耦合会导致脆弱的设计,当发生变化时,设计会遭受到意想不到的破坏。...void LogToDB(T msg); public void LogToWindows(T msg); } 这个例子定义了一个日志类,包含三种方法:将日志写入本地文件、数据库或...为什么要遵循此原则? 我们要遵循OCP原则,OCP背后的机制是抽象和多态,支持抽象和多态的关键机制是继承(比如C#是这样),那么是什么设计规则支配着这种继承用法?最佳的继承层次特征是什么?...该原则是框架设计的核心。 为什么要遵守此原则? 如果高层模块依赖于低层模块,那么对低层模块的改动会直接影响到高层模块,从而迫使他们一次做出改动。 违反原则的情形 高低层组件通过具体类来实现交互。...三、控制反转(IoC) 控制反转是基于面向对象的原则,提倡松耦合理念的设计原则,允许独立开发应用程序的各个组件。 实现方式 实现方式有两种:依赖注入,服务定位。

72471

设计原则

设计原则 ? 有句古老的谚语说:“愚弄我一次,应该羞愧的是你。再次愚弄我,应该羞愧的是我。”这也是一种有效的对待软件设计的态度。为了防止软件背着不必要的复杂性,我们会允许自己被愚弄一次。...——《敏捷软件开发原则、模式与实践》 好的代码永远是需要设计的。一名高级程序员,更应该有设计师的潜质,不只是关注怎么用代码实现业务,更关注的是代码的设计。...JavaScript用得上设计原则有单一职责原则、里氏替换原则、依赖倒置原则、接口隔离原则、合成复用原则和最少知识原则等。本文将选取三个常用的阐述之。...需要明确的是:设计原则只是一种指导,没有哪条原则是在实际开发中必须遵守的。但善用原则,可以帮助更好地设计代码。 1 单一职责原则(srp) 概述 定义:就一个类而言,应该仅有一个引起它变化的原因。...在面向对象的程序设计中,开放封闭原则(OCP)是最重要的一条原则。很多时候,一个程序具有良好的设计,往往说明它是符合开放封闭原则的。

52720

设计原则之开闭原则

所谓对扩展开放,对修改关闭,其实是设计模式里面所重点提倡的,后续所有涉及模式的介绍其实都是为了程序能够更好的扩展,提倡设计模式的本质就是为了减少 增加一点功能而修改系统的主要逻辑!...StringFormatUtil.stringFormat(MSG)); } } 程序必须首先让人类理解,然后顺便让机器能执行^_^xxxx Process finished with exit code 0 总结 通过上述代码可以知道,开闭原则是是为了避免过多的修改原有的代码逻辑...,用扩展代替修改而衍生的一个原则,不可否认,他也是所有的设计模式都想表达的一个结果,高扩展性。...开闭原则也并不是免费的。有些情况下,代码的扩展性会跟可读性相冲突。比如,我们之前举的 StringFormat格式化的例子。

61830

关系数据库设计_关系型数据库设计原则

文章目录 一、关系数据库设计理论 二、规范化 1、第一范式(1NF) 2、第二范式(2NF) 3、第三范式(3NF) 4、巴斯-科德范式(BCNF) 【目的原则】 【反范式(了解)】 一、关系数据库设计理论...1、设计一个合适的关系数据库系统的关键是关系数据库模式的设计,即应构造几个关系模式, 每个模式有哪些属性,怎样将这些相互关联的关系模式组建成一个适合的关系模型,关系数据库设计必须在关系数据库设计理论的指导下进行...2、关系数据库设计理论有三个方面的内容:函数依赖、范式和模式设计。函数依赖起核心作用, 它是模式分解和模式设计的基础,范式是模式分解的标准。...说明:在任何一个关系数据库中,第一范式(1NF)是对关系模式的设计基本要求,一般设计中都必须满足第一范式(1NF)。不过有些关系模型中突破了1NF的限制,这种称为非1NF的关系模型。...而真正的第四范式,则是在设计规范中添加了对多值及依赖的要求。 【目的原则】 规范化目的是使结构更合理,消除存储异常,使数据冗余尽量小。便于插入、删除和更新。

2K10

设计原则(1)| 开闭原则

这些操作都是通过「修改」来实现新功能的,不符合「开闭原则」。 如果我们要遵循「开闭原则」,必须对修改关闭,对扩展开放。...其次,「开闭原则」的定义是软件实体(模块、类、方法等)应该对扩展开放,对修改关闭。...所有的设计原则都只有一个最终归宿——不破坏原有代码的正常运行,方便扩展。...但是想识别出所有可能的扩展点既不可能也没必要,最合理的做法是对一些比较确定的、短期内可能会发生的需求进行扩展设计。...还是那句话,设计原则设计模式不是金科玉律,只要适合当前需求,并具备一定弹性的设计就是好设计。要平衡代码扩展性和可读性,切勿滥用设计原则设计模式,牺牲代码的可读性。

56320
领券