数据库调优积累系列(4):数据库设计
创始人
2024-07-26 04:30:49
0

数据库设计:

1、如果某表经常出现死锁,那就要做对象职责分离,就是把插入、更新、删除等分离;

2、在设计或创建表的时候,我们往往会把Id字段设置为聚集索引,但是我们这样的习惯可能不是***的,因为聚集索引和非聚集索引的区别就是一个是物理存储的,所以在查询的时候如果使用聚集索引的话,可能会比非聚集索引要开,因为关系到数据页的分布,因此我们有时可以根据我们的需要来设置聚集索引,比如待办待阅一般都是按照时间来倒排的,那我们可以让日期字段来做聚集索引;

 3、当表的数据量比较大,而且一些基本的优化也不能满足到需求,那就可以考虑:纵向、横向分割表,减少表的尺寸(sp_spaceuse);

 4、表字段如果不为空的,就不应该设置允许空,***:这里可以确保数据的完整性;第二:依稀记得跟性能有关,但是记不起,欢迎补充;

 5、在表中设计索引属性的时候,我们都会看到填充因子,通常情况下我们都是不去理会它的,如果我们去了解它,也许我们会有不错的回报。(以下是个人言论,有可能存在BUG,不久将来会进一步确认是否正确。)

a、填充因子的意思就是当数据页的数据达到多少百分比的时候就换页,相当以在数据页中预留多少空间来应对数据的增长,比如聚集索引,如果我们选择了100%或者0%,意思就是我们要把整个数据页都填充完整;
b、如果该表有一个以ID自增为聚集索引,而且我们设置的这个比值比较小,就会有可能造成比较多的磁盘碎片,查询时的IO消耗比较大,这是因为聚集索引在数据页的表现是物理存储,索引每个数据页都会留下比较多的数据页空间,而且是永远都不会给使用到的;

 c、只有当索引被创建或者是重建时才会重新设置数据页的百分比分布,当做插入数据后,改数据页的比例就会小于这个百分比了;
 

关于数据库设计的知识就为大家介绍到这里,相信通过上文中的介绍大家对数据库设计已经了解了,希望大家都能够从中有所收获。

【编辑推荐】

  1. 数据库设计中的五个范式
  2. 数据库设计流程
  3. 空间换时间的数据库设计
  4. 改进数据库的查询性能
  5. 详解降低数据库连接数的方法

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...