数据库身份证号用什么类型_数据库设计规范

数据库身份证号用什么类型_数据库设计规范引擎规范非特殊情况下,默认选择Innodb,支持事务、行级锁,并发性能更好。编码规范UTF-8表设计规范必须有主键主键递增,可提高写入性能,减少碎片禁止使用外键降低表之间的耦合,不要涉及更新操作的级联,并发高情况极度影响SQL性能字段设计规范必须有注释不然鬼才知道代表什么意思必须NOTNULLnull的列不能使用索引整形默认int(11)0。int(11)代表显示长度,在勾选无符号unsig…

大家好,又见面了,我是你们的朋友全栈君。

9e078fe8bcfe65e8525c009613f8eb7f.png

引擎规范

非特殊情况下,默认选择Innodb,支持事务、行级锁,并发性能更好。

编码规范

UTF-8

设计规范

必须有主键

主键递增,可提高写入性能,减少碎片

禁止使用外键

降低表之间的耦合,不要涉及更新操作的级联,并发高情况极度影响SQL性能

字段设计规范

必须有注释

不然鬼才知道代表什么意思

必须NOT NULL

null的列不能使用索引

整形

默认 int(11) 0。int(11)代表显示长度,在勾选无符号unsigned并且填充零zerofill后如果长度不够11位会自动补零,如插入1,显示00000000001,选择需要为unsigned。

字符串

默认空字符串

时间

非current_timstamp(mysql5版本不支持该语法)默认’1970-01-01 08:00:01’,date类型无时分秒

通用字段

create_time(created_at):创建时间,默认current_timestamp

update_time(updated_at):更新时间,默认current_timestamp,on update current_timestamp

is_deleted:逻辑删除标志位,视情况选择

禁止使用textblob

浪费磁盘和内存空间,影响数据库性能

金额禁止使用小数存储

尽量使用分或者更小的单位用整数存储,否则精度的问题会很麻烦

命名规则

表、列

使用业务模块开头,如tb_order,列名以下划线分割

索引

create_time、update_time必须包含索引

主键索引

数据库自动

唯一索引、组合唯一索引

uk_colName_colName

普通索引、组合普通索引

idx_colName_colName

建表示例

CREATE TABLE `user` (
  `id` int unsigned NOT NULL AUTO_INCREMENT,
  `username` varchar(128) NOT NULL DEFAULT '' COMMENT '用户名',
  `cert_no` varchar(64) NOT NULL DEFAULT '' COMMENT '身份证号',
  `gender` tinyint NOT NULL DEFAULT '0' COMMENT '性别0女1男',
  `active_date` date NOT NULL DEFAULT '1970-01-01' COMMENT '激活时间',
  `inactive_time` datetime NOT NULL DEFAULT '1970-01-01 08:00:01' COMMENT '失效时间',
  `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  PRIMARY KEY (`id`),
  UNIQUE KEY `idx_cert_no` (`cert_no`) USING BTREE,
  KEY `idx_username_gender` (`username`,`gender`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

5b06a82f6f4a5fb17c6e2f47d148adbc.png
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/160431.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • android自定义toast样式_android设置对话框宽度

    android自定义toast样式_android设置对话框宽度在一般的android开发中我们一般弹出一些提示信息,例如已打开蓝牙,wifi之类的提示,我们都是会选择Toast进行弹出。今天我们的客户提出们应用弹出提示太小,用户不注意的情况下,容易被忽略掉,要弹出的宽度填充整个屏幕,首先想到是不是需要自定义Toast,经过自己的一番研究后,发现不需要自定Toast,用现有的Toast就可以轻松实现了。publicvoidshowToast(Cont

    2022年9月13日
    0
  • 莫兰迪色系表

    莫兰迪色系表莫兰迪色系????它曾因《延禧攻略》的播出而大受追捧它饱和度不高带有几分淡漠疏离的色调却也使得空间柔和自然舒缓雅致展现出静态的和谐之美它别称“高级灰”它也被誉为世界上最舒服的配色它便是莫兰迪色系????莫兰迪色系:高级灰色调。不鲜亮,仿佛蒙了一层灰调,不张不扬,却在整个画面中,相互制约、相互抵消,让视觉达到完美平衡。它给人以平和自持、舒缓雅致,有时略显冷静的感觉,让人越看越喜欢。????颜色效果16进制值RGB值颜色效果

    2022年5月17日
    152
  • 数据库课程设计(饭店点餐系统)

    数据库课程设计(饭店点餐系统)1.需求分析2.概念结构设计2.1数据需求2.1.1下订单阶段需要的数据:2.1.2点菜阶段需要的数据:2.1.3结账阶段需要的数据:2.1.4员工管理需要的数据:2.1.5顾客管理需要的数据:2.1.6消费记录管理需要的数据有:2.2事务需求2.2.1数据录入2.2.2数据更新/删除2.2.3数据查询2.3数据项2.2抽象出系统的实体2.3设计E-R图2.3.1菜谱(Menus)E-R图2.3.2顾客(Tomer)E…

    2022年5月12日
    78
  • 宝塔服务器管理助手Linux面版-使用教程

    宝塔服务器管理助手Linux面版-使用教程

    2021年9月22日
    43
  • phpstorm 2021激活码3月最新在线激活

    phpstorm 2021激活码3月最新在线激活,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    65
  • 圆桌排序公式_大圆桌怎么坐

    圆桌排序公式_大圆桌怎么坐假设有来自 m 个不同单位的代表参加一次国际会议。每个单位的代表数分别为 ri(i=1,2,…,m)。会议餐厅共有 n 张餐桌,每张餐桌可容纳 ci(i=1,2,…,n) 个代表就餐。为了使代表们充分交流,希望从同一个单位来的代表不在同一个餐桌就餐。试设计一个算法,给出满足要求的代表就餐方案。输入格式第 1 行有 2 个正整数 m 和 n,m 表示单位数,n 表示餐桌数。第 2 行有 m 个正整数,分别表示每个单位的代表数 ri。第 3 行有 n 个正整数,分别表示每个餐桌的容量 ci。输

    2022年8月10日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号