MySQL数据库命名规范及约定

PS:MySQL数据库命名规范及约定!

操作规范

  1. 如无备注,则数值类型的字段请使用UNSIGNED(无符号)属性
  2. 如无备注,排序字段order_id在程序中默认使用降序排列
  3. 如无备注,所有字段都设置NOT NULL,并设置默认值
  4. 字段注释,统一为类似格式
    1. 多类型字段(发送状态:1未发送,2发送中,3发送完成,4发送失败)
    2. 单文本注释(随便写)
  5. 所有的数字类型字段,都必须设置一个默认值,并设为 0
    1. 所有针对状态型字段,如文章的状态字段status可能包含多种可能,不能设置0这种可能状态,必须从1开始,举例(1删除 2已发布 3 未发布 4审核未通过 5未审核)
    2. 所有针对分类型字段,如文章的分类状态字段cid可能包含多种可能,不能设置0这种可能状态,必须从1开始,举例(1新闻 2杂志)
    3. 所有针对布尔值字段,如文章的是否是热帖状态字段is_hot,不能设置0这种可能状态,必须从1开始,举例(1默认 2热帖)
  6. 针对varchar类型字段的程序处理,请验证用户输入,不要超出其预设的长度;
  7. 建表时将数据字典中的字段中文名和属性备注写入数据表的备注中(“PK、自动增长”不用写);
  8. 如无说明,建表时一律采用innodb引擎;

常用表名约定

discuzx3.1表结构
phpcms_phpsso表结构
phpcmsv9表结构
说明:表前缀用项目名称首字母缩写;所以表名都小写,单词之间用下划线分开,单词都用单数形式

字段名 说明
user 用户
category 分类
goods 商品、产品等一切可交易网站的物品都用此命名
good_gallery 物品的相册
good_cate 物品的分类,除了单独作为表名,其他地方分类单词一律用缩写cate
attr 属性
article 文章、新闻、帮助中心等以文章形式出现的,一般都用此命名
cart 购物车
feedback 用户反馈
order 订单
site_nav 包括页头和页尾导航
site_config 系统配置表
admin 后台用户 【RBAC标准表】
role 后台用户角色【RBAC标准表】
access 后台操作权限,相当于action【RBAC标准表】
role_admin 后台用户对应的角色【RBAC标准表】
access_role 后台角色对应的权限【RBAC标准表】

常用列名约定

说明:所以列名都小写,单词之间用下划线分开,单词都用单数形式

字段名 说明
表名_id 通常用作外键命名
cid 特殊的编号,带有元数据,方便关联查询,你可以把它理解成类别(层次)编号。举个例子,产品在分类时,往往需要将其归类到子分类下,相应的字段中也一般只记录子分类的id,这时若需要知道该产品属于哪个主分类,就需要通过子分类信息再查询到主分类信息,这是比较麻烦的,cid字段就是要解决这个问题。一般的站点几十个分类肯定是够用了,所以这里假设某一主分类的cid为11,则子分类的cid从1101开始编号,处理时只需截取前两位数值便可知道该产品属于哪一个主分类了。
time_add 添加时间、上架时间等
time_mod 最后操作时间,如登录、修改记录
time_expire 过期时间
name 商品名称、商家名称等,不要跟title混用,title只用于文章标题、职称等
price 价格
thumb 只要是列表页面中的窗口图,一律用此命名
image_src 相册中的图片地址一律用此命名,不要出现各种img,image,img_url,thumb_url等
head_thumb 用户头像, 虽然有点长,一定要遵守。不要出现上述情况
image_alt 相册中图片的alt属性
desc 描述、简介,比如goods_desc,不要出现goods_txt这种
details 详情、文章内容等
order_id 排序
telephone 座机号码
mobile 手机号码
phone 当不区分手机和座机时,请用phone命名
address 地址,单独出现不要用addr缩写,组合出现时需用缩写,比如mac地址,mac_addr
zipcode 邮编
region 地区,大的区域,比如记录杭州市、温州市等
area 区域,小的,比如上城区,江干区等
avg_cost 人均消费
字段名 列名 类型 属性备注 说明
流水号 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(3)
排序 order_id int(10)
是否删除 is_del tinyint(3) 是否删除:1:未删除 2:已删除
审核时间 auditTime int(10)
相关文章
  1. 理解MySQL——索引与优化(转载)
  2. MySQL索引背后的数据结构及算法原理
  3. MySQL数据备份和binlog数据恢复案例分析
  4. mysql binlog详解
  5. MySQL Replication(Master与Slave基本原理及配置)
  6. MySql常用命令总结
本站版权
1、本站所有主题由该文章作者发表,该文章作者与尘埃享有文章相关版权
2、其他单位或个人使用、转载或引用本文时必须同时征得该文章作者和尘埃的同意
3、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
4、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
5、原文链接:
二维码
Posted in mysql, 数据库技术
Comments are closed.