表结构定义优化的专题报告
admin
2023-05-27 14:41:48
0
专题描述阅读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个字节


相关内容

热门资讯

湖南石门强降雨搜救持续:村民守... 澎湃新闻记者 廖艳 实习生 林霄自5月17日7时起,湖南常德石门县遭遇极端强降雨天气,瞬时雨量大、致...
美新远程空空导弹初露真容,能缓... 澎湃新闻特约撰稿 王若鸿近日,美国一位航空摄影师拍摄到几架从佛罗里达州埃格林空军基地起飞的美国海军测...
官方通报福建漳州“泡药杨梅”事... 【大河财立方消息】 5月20日晚,福建漳州市食品安全委员会办公室通报:5月15日,媒体报道反映漳州市...
山河湖海,算算生态环境的“三本... 【大河财立方 记者 程帅星 北京报道】 5月20日下午,国务院新闻办公室举行2026年“新征程上的奋...
官方通报“儿童乳膏涉嫌非法添加... 【大河财立方消息】针对今年3月媒体反映广西十安生物科技有限公司生产的“消字号”产品涉嫌非法添加问题,...
山西通报“明长城被露天煤矿长期... 5月20日,山西宁武县委宣传部发布情况通报:近日,有媒体报道神达朝凯煤业相关问题。宁武县委、县政府高...
国务院被掏空,美国外交陷入“空... ◆在美国国务卿鲁比奥的主导下,国务院正全面围绕特朗普的核心议程进行改革。(图源:美联社)文/方晨宇编...
美军“尼米兹”号航母进入加勒比... 新华社华盛顿5月20日电(记者黄强 徐剑梅)美军南方司令部20日在社交媒体发布消息说,美军“尼米兹”...
28个暴雨红色预警信号生效中,... 20日晚,粤西到珠三角南部一带强降水仍在持续,暖湿气流源源不断补充,导致新生成的强降雨云团不断在同一...
中构建筑取得钢结构厂房用可伸缩... 国家知识产权局信息显示,中构建筑有限公司取得一项名为“一种钢结构厂房用可伸缩式抗风支撑杆”的专利,授...