问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

mysql数据库列明名问题

发布网友 发布时间:2022-05-03 07:11

我来回答

2个回答

懂视网 时间:2022-05-03 11:32

-s标识,备库在名称后加-ss标识 线上从库:ali.xxx-s.db 线上备库:ali.xxx-ss.db 注: ali为公司名称缩写

表命名规范

规范

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

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

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

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

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

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

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

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

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

约定

  1. 说明:表前缀用项目名称首字母缩写;所以表名都小写,单词之间用下划线分开,单词都用单数形式
  2. user – 用户
  3. category – 分类
  4. goods – 商品、产品等一切可交易网站的物品都用此命名
  5. good_gallery – 物品的相册
  6. good_cate – 物品的分类,除了单独作为表名,其他地方分类单词一律用缩写cate
  7. attr – 属性
  8. article – 文章、新闻、帮助中心等以文章形式出现的,一般都用此命名
  9. cart – 购物车
  10. feedback – 用户反馈
  11. order – 订单
  12. site_nav – 包括页头和页尾导航
  13. site_config – 系统配置表
  14. admin – 后台用户 【RBAC标准表】
  15. role – 后台用户角色【RBAC标准表】
  16. access – 后台操作权限,相当于action【RBAC标准表】
  17. role_admin – 后台用户对应的角色【RBAC标准表】
  18. access_role – 后台角色对应的权限【RBAC标准表】
  19. 待续

范例

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

字段命名规范

规范

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

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

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

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

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

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

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

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

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

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

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

  2.  

    可能关联多个不同表的id的字段建议叫 RELATION_ID(关联id)
    ? 时间以字段以 _TIME 后缀结尾
    ? 带有标识的字段以 _FLAG 后缀结尾
    ? 自定义code码字段以 _CODE 后缀结尾
    ? 所有使用0,1,2等字段代表特殊含义的需要在字段注释中说明清楚,码中说明清楚,修改了定义规则需要及时修改数据库注释。

约定

  1. 表名_id – 通常用作外键命名
  2. cid – 特殊的编号,带有元数据,方便关联查询,你可以把它理解成类别(层次)编号。举个例子,产品在分类时,往往需要将其归类到子分类下,相应的字段中也一般只记录子分类的id,这时若需要知道该产品属于哪个主分类,就需要通过子分类信息再查询到主分类信息,这是比较麻烦的,cid字段就是要解决这个问题。一般的站点几十个分类肯定是够用了,所以这里假设某一主分类的cid为11,则子分类的cid从1101开始编号,处理时只需截取前两位数值便可知道该产品属于哪一个主分类了。
  3. add_time – 添加时间、上架时间等
  4. last_time – 最后操作时间,如登录、修改记录
  5. expire_time – 过期时间
  6. name – 商品名称、商家名称等,不要跟title混用,title只用于文章标题、职称等
  7. price – 价格
  8. thumb – 只要是列表页面中的窗口图,一律用此命名
  9. image_src – 相册中的图片地址一律用此命名,不要出现各种img,image,img_url,thumb_url等
  10. head_thumb – 用户头像, 虽然有点长,一定要遵守。不要出现上述情况
  11. image_alt – 相册中图片的alt属性
  12. desc – 描述、简介,比如goods_desc,不要出现goods_txt这种
  13. details – 详情、文章内容等
  14. order_id – 排序
  15. telephone – 座机号码
  16. mobile – 手机号码
  17. phone – 当不区分手机和座机时,请用phone命名
  18. address – 地址,单独出现不要用addr缩写,组合出现时需用缩写,比如mac地址,mac_addr
  19. zipcode – 邮编
  20. region – 地区,大的区域,比如记录杭州市、温州市等
  21. area – 区域,小的,比如上城区,江干区等
  22. avg_cost – 人均消费
  23. 待续

字段01标记
DEL_FLAG 逻辑删除标记,0未删除,1删除

索引命名规范

规则

普通索引:IDX_字段名
唯一索引:IDX_UQE_字段名
组合索引:IDX_COM_字段名_字段名_字段名

添加索引sql

 添加主键索引
 ALTER TABLEtable_nameADD PRIMARY KEY (column)

 添加唯一索引
 ALTER TABLEtable_nameADD UNIQUE (column)

 添加全文索引
 ALTER TABLEtable_nameADD FULLTEXT (column)

 添加普通索引
 ALTER TABLEtable_nameADD INDEX index_name (column)

 添加组合索引
 ALTER TABLEtable_nameADD INDEX index_name (column1,column2,column3)

不需要使用索引情况:

 表比较小,数据量不会多

 赋值有限的列(枚举),不要创建索引。创建的索引返回的行越少越好,此时区分度大。

 用不上索引的列,不要创建索引。

 长字符串的列,不要全部创建索引,但可以使用短索引(名字的头8个字符)。

使用索引:
 可能用到索引的地方:where 子句,order by,group by
 索引有效的情况,使用如下筛选条件:
 <,<=,=,>,>=,between,in,like’admin%’,独立索引+or+独立索引+mysiam

索引失效

 is not null 或 is null 索引会失效

 not in 或<> 或!=

 like查询是以%开头,不使用索引。like ‘%admin’

 关联表的id需要和关联表中的id的字符集,排序集一致,否则关联不会使用索引检索。

 or+innodb

 字符类型在where子句中不加引号,不使用索引

 对字段加函数或者运算的

 在order by操作中,mysql只有在排序条件不是查询条件表达式时才使用索引。尽管如此,在涉及多个数据表的查询里,即使有索引可用,那些索引在加快ORDER BY操作方面也没什么作用。

 select 语句中字段中的子查询是不使用索引的,除非添加必要的别的条件来使用索引。
 如:SELECT scolumn.ID,( SELECT COUNT(ID)FROMS_COMMENT AS discuss WHERE discuss.RELEVANCE_ID = article.SEQUENCE_ID‘ AND discuss.CODE =‘资讯平路‘) AS discussCount FROM S_COLUMN AS scolumn LEFT JOIN S_ARTICLE AS article ON scolumn.ID = article.COLUMN_ID LEFT JOIN S_COMMON_ARTICLE AS commonArticle ON commonArticle.ARTICLE_ID = article.ID
 这个子查询中 article.SEQUENCE_ID 和 RELEVANCE_ID都有索引确不会使用,而是用的是code的索引,所以要避免selec中子查询。

 连接查询时,如果关联字段排序字符集不一样,则索引会失效,此点需在建表时注意。

 如果mysql估计使用全表扫描要比使用索引快,则不使用索引。

 比如:列id均匀的分布在1-100之间。下面的sql则不会使用索引  `select * from table_name where id > 1 and id<90;` 
 1

 



MySQL_数据库命名规范及约定

标签:类别   sql语句   统一   常用   字段排序   排列   def   列表   ESS   

热心网友 时间:2022-05-03 08:40

1.你是不可能成功建表的。列名可以使用‘_’不可以使用‘-’。
2.一般都遵照程序的变量或类名命名规范比较保险。字母开头 里面加下划线或数字 这样怎么样都不会错。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
脾基本简介 人体有2个脾脏吗 百度百科 人的脾有几个 我是无锡的,公司需要办理健康证,请问应该到哪里去办理? 儿童健康小常识:让宝宝快乐成长 如何构建认罪认罚案件相对不起诉适用标准 相对不起诉概述 杨笠脱口秀称男人没底线,直言没有男人生活会更幸福,你认可吗? 每个人都是独立的个体都有自己生活的选择方式和权利,别人不要干涉... ...人观点,是我的自由、我的权利别人无权 干涉”这种观点 我刚刚玩网,求帮我想个好听的名字 华彩人生非交易时间可以登录吗 有没有好听的组织名字 都是女的 绝地求生未来之役怎么屏蔽世界消息 有什么好听的组织名字 有几个说几个 谢谢啊 有急用 大家帮忙给游戏的组织起个名字 玩游戏 有没有好听的杀手组织和杀手名字 最好是中国古.风的 我悬赏高的 越多越好 要精品 求一个好听的组织名字。游戏的组织名称、 吃鸡语音频道被禁了什么时候解除 好听的组织名字有哪些? 帮我想个好听的组织名、关于网络里的, JNDI中 java:comp/env 是什么意思? env | grep oracle什么意思 陶渊明是中国什么派诗人 在bash下执行命令set,env有什么区别 诗圣,诗仙,诗鬼,山水诗人,田园诗人各是指谁? .env的APP_KEY什么意思 第一位田园诗人 硬盘数据线上SATA 24&quot;ENV是什么意思啊? envtb是什么意思 五菱NanoEV配置曝光,续航305公里,这款车的安全性能如何? 印度汽车两万八在西宁有售吗 NANO汽车在中国有买吗 五菱NanoEV综合续航能到305公里,除了跑的快这款车还有哪些优势? 塔塔NANO的特点 平衡车nano和l6区别 五菱NanoEV好不好,值得购买吗? 适合农村发展的新商机 九牧王修身版175/80是多少码的 五菱NANO EV申报图 外观活泼时尚/定位入门级电动车 爱贝芙的心里准备 比如我是政府 我要建立哪种类型的公众 印度塔塔的NANO汽车在中国有卖的吗? 那些在农村也能赚到钱的人,主要从事的是哪些行业? 除皱最佳的年龄是多大呢? 手术除皱、注射除皱,哪些安全呢? 九牧王的裤子代码JB172084T代表什么意思? 九牧王(泉州)有限公司怎么样? 为什么好多明星自己代言护肤品 他们自己都不用? 五菱nanoev嗯刮器怎么样喷水 回农村创业有哪些商机