代码改变世界

数据库调优积累系列(4):数据库设计

  听风吹雨  阅读(738)  评论(0编辑  收藏  举报
数据库设计
  1. 如果某表经常出现死锁,那就要做对象职责分离,就是把插入、更新、删除等分离;
  2. 在设计或创建表的时候,我们往往会把Id字段设置为聚集索引,但是我们这样的习惯可能不是最优的,因为聚集索引和非聚集索引的区别就是一个是物理存储的,所以在查询的时候如果使用聚集索引的话,可能会比非聚集索引要开,因为关系到数据页的分布,因此我们有时可以根据我们的需要来设置聚集索引,比如待办待阅一般都是按照时间来倒排的,那我们可以让日期字段来做聚集索引;
  3. 当表的数据量比较大,而且一些基本的优化也不能满足到需求,那就可以考虑:纵向、横向分割表,减少表的尺寸(sp_spaceuse);
  4. 表字段如果不为空的,就不应该设置允许空,第一:这里可以确保数据的完整性;第二:依稀记得跟性能有关,但是记不起,欢迎补充;
  5. 在表中设计索引属性的时候,我们都会看到填充因子,通常情况下我们都是不去理会它的,如果我们去了解它,也许我们会有不错的回报。(以下是个人言论,有可能存在BUG,不久将来会进一步确认是否正确。)
    1. 填充因子的意思就是当数据页的数据达到多少百分比的时候就换页,相当以在数据页中预留多少空间来应对数据的增长,比如聚集索引,如果我们选择了100%或者0%,意思就是我们要把整个数据页都填充完整;
    2. 如果该表有一个以ID自增为聚集索引,而且我们设置的这个比值比较小,就会有可能造成比较多的磁盘碎片,查询时的IO消耗比较大,这是因为聚集索引在数据页的表现是物理存储,索引每个数据页都会留下比较多的数据页空间,而且是永远都不会给使用到的;
    3. 只有当索引被创建或者是重建时才会重新设置数据页的百分比分布,当做插入数据后,改数据页的比例就会小于这个百分比了;
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示