好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

数据库表及字段命名规范(一)

四、【数据表字段设计范例】

分类表(t_category)

字段名

列名

类型

属性备注

说明

流水号

id

int(10)

PK、自动增长

特殊编号

cid

varchar(4)

第一个主分类为11、第一个子分类为1101,类推,仅支持二级分类

名称

name

varchar(10)

页面中需注明输入不超过10个字

父分类

pid

int(10)

统计量

count

int(10)

是否热门

is_hot

tinyint(1)

首页显示

is_index

tinyint(1)

排序

order_id

int(10)

 

 五、[表命名规范]

1.具备统一前缀,对相关功能的表应当使用相同前缀,如acl_xxx,house_xxx,ppc_xxx;其中前缀通常为这个表的模块或依赖主实体对象的名字,通常来讲表名为:业务_动作_类型,或是业务_类型;

2.表名使用英文小写单词,如果有多个单词则使用下划线隔开;

3.表名简介,使用常见单词,避免使用长单词和生僻词;

4.表引擎取决于实际应用场景及当前数据库中的已经存在的存储引擎;日志及报表类表建议用myisam,与交易,审核,金额相关的表建议用innodb引擎。总体来讲数据库默认innodb;

5.数据表必须有主键,且建议均使用auto_increment的id作为主键(与业务无关),和业务相关的要做为唯一索引;

6.默认使用utf8字符集(由于数据库定义使用了默认,数据表可以不再定义,但为保险起见,建议都写上);

7.所有的表都必须有备注,写明白这个表中存放的数据内容;

8.预估表数据量,如果数据量较大(超过500w)则需要考虑分表策略。可以等量均衡分表或根据业务规则分表均可。要分表的数据表必须与DBA商量分表策略;

9.职责相近的表,命名规则应该相同;如合同申请,账户信息,交友相关等;

举个例子,一张在线冲值记录表:user_bank_deposit这个就非常符合标准,如果叫做userBankDeposit或是user_chongzhi,就非常不友好。

CREATE TABLE `house_refresh_log` (

  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增ID',

  `fangid` int(11) NOT NULL COMMENT '房贴子ID',

  `refresh_time` int(11) NOT NULL COMMENT '刷新时间',

  PRIMARY KEY (`id`),

  UNIQUE KEY `fangid` (`fangid`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='房刷新记录表';

[字段命名规范]

1.数据库字段命名与表名命名类似:

2.使用小写英文单词,如果有多个单词使用下划线隔开;

3.使用简单单词,避免生僻词;

4.字段应当有注释,描述该字段的用途及可能存储的内容,如枚举值则建议将该字段中使用的内容都定义出来;

5.是别的表的外键均使用xxx_id的方式来表明;

6.表的主键一般都约定成为id,自增类型;

7.时间字段,除特殊情况一律采用int来记录unix_timestamp;

8.网络IP字段,除特殊情况一律用bigint来记录inet_aton值;

9.所有字段,均为非空,最好显示指定默认值;

10.有些驱动对tinyint支持不够好,通常建义按容量来选择字段;

11. text字段尽量少用,或是拆到冗余表中;

CREATE TABLE `wanted_post` (

  `id` int(10) NOT NULL AUTO_INCREMENT,

  `puid` int(10) unsigned NOT NULL,

  `user_id` int(10) NOT NULL COMMENT '发贴用户的id',

  `username` varchar(50) NOT NULL COMMENT '发贴用户的用户名',

  `city` smallint(4) NOT NULL COMMENT '所在城市',

  `ip` bigint(14) NOT NULL COMMENT '发帖人的ip',

  `district_id` tinyint(2) NOT NULL COMMENT '所在区域的id',

  `district_name` varchar(20) NOT NULL COMMENT '行政区名字',

  `street_id` tinyint(2) NOT NULL COMMENT '所在街道(地标)的id',

  `street_name` varchar(20) NOT NULL COMMENT '小区名字',

  `title` varchar(255) NOT NULL COMMENT '帖子的标题',

  `description` text NOT NULL COMMENT '帖子详情描述',

  `post_at` int(11) NOT NULL COMMENT '用户发帖时间,数据创建的时间,使用整型存储',

  `refresh_at` int(11) NOT NULL COMMENT '帖子被修改的时间,整型存储',

  `show_time` int(11) NOT NULL COMMENT '帖子显示时间',

  `age_max` int(11) NOT NULL DEFAULT '0' COMMENT '招聘最小年龄',

  `age_min` int(11) NOT NULL DEFAULT '0' COMMENT '招聘最大年龄',

  `post_refresh_at` int(11) NOT NULL COMMENT '刷新时间',

  PRIMARY KEY (`id`),

  UNIQUE KEY `idx_puid` (`puid`),

  KEY `user_id_index` (`user_id`),

  KEY `post_at_index` (`post_at`),

  KEY `refresh_at_index` (`refresh_at`),

  KEY `show_time_index` (`show_time`)

) ENGINE=InnoDB AUTO_INCREMENT=55295 DEFAULT CHARSET=utf8 COMMENT='招聘帖子表';

 

查看更多关于数据库表及字段命名规范(一)的详细内容...

  阅读:1478次