返回顶部
首页 > 资讯 > 数据库 >表结构定义优化的专题报告
  • 548
分享到

表结构定义优化的专题报告

2024-04-02 19:04:59 548人浏览 独家记忆
摘要

专题描述阅读Ecbil项目的数据库表结构定义,发现存在普遍共性的不合理地方,整理成专题报告供研发团队和DBA团队优化,及辅佐今后的表结构定义设计。问题提出1示例表结构定义:2`id` BIGINT

专题描述阅读Ecbil项目数据库表结构定义,发现存在普遍共性的不合理地方,整理成专题报告供研发团队和DBA团队优化,及辅佐今后的表结构定义设计。
问题提出1示例表结构定义:表结构定义优化的专题报告
2`id` BIGINT(20) UNSIGNED NOT NULL,PRIMARY KEY (`id`)
3`dept_name` VARCHAR(128) DEFAULT NULL COMMENT '机构名称'
4`dept_desc` VARCHAR(512) DEFAULT NULL COMMENT '机构描述'
5`type_level` DECIMAL(4,0) DEFAULT NULL COMMENT '类型层次'
6`email_addr` VARCHAR(128) DEFAULT NULL
7`belong_county` VARCHAR(1024) DEFAULT NULL
8`update_tm` DATETIME DEFAULT NULL
9UNIQUE KEY `idx_department_1` (`dept_code`) USING BTREE,
KEY `IDX_DEPARTMENT_DEPT_CODE` (`dept_code`)
10 `cod_state` char(5) DEFAULT NULL
分析过程1咨询研发团队对应的系统界面输入框限制
2分析表结构定义
解决方案1字段定义长度比前端页面的输入框限制适度放大点,比如增加5%-10%
2邮箱地址的行业标准40个字符左右,例如belong_county、belong_village等字符类型的字段
3type_level等类型字段的数值范围,可以选择 UNSINGED 的TINYINT和SMALLINT
4除主键和业务特殊的字段外,所有字段设置默认值,建议:数值类型字段默认值为0,字符串类型默认值为''空字符串;日期类型默认值为'0000-00-00'
5Mysql数据库的主键、唯一键和外键,都具有索引的功效
6除出生日期等特殊存储要求外,其他日期数据全使用存储空间更小和完整时间功能的TIMESTAMP日期类型
7InnoDB存储引擎的缘故,建议不使用CHA(N),直接全部使用VARCHAR(N)
问题原因1字段定义长度严重超过业务方需求无实际意义,还会导致数据写入的性能问题
2指定默认值有利于简化程序的处理异常复杂度和增加可读性
知识点1mysql数据库VARCHAR(N)中的N是表示多个字符,不同于oracle和MSsql的字节个数表示
2DATETIME日期类型占用8个字节,TIMESTAMP占用4个字节


您可能感兴趣的文档:

--结束END--

本文标题: 表结构定义优化的专题报告

本文链接: https://lsjlt.com/news/43270.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作