数据库表设计

一、数据库表设计三范式

  1. 三范式

  1. 第一范式理解

关键点:列都是不可再分,第一范式的目标是确保每列的原子性,每列都是不可再分的最小数据单元

  • 不满足第一范式举例

  • 满足第一范式举例

  1. 第二范式理解

关键点:首先满足第一范式,并且表中非主键列不存在对主键不依赖或者部分依赖,确保每个列都和主键相关。一般因为是存在多个主键,或者存在复合主键,因此需要拆表

  • 不满足第二范式举例

  • 满足第二范式举例

  1. 第三范式理解

关键点:满足第二范式,并且表中的列不存在对非主键列的传递依赖,每列都和主键列直接相关,而不是间接相关

  • 不满足第三范式举例

  • 满足第三范式举例

二、表设计类型定义几个点区别

  1. 字符类型和长度整数类型长度区别

  1. 带符号和不带符号区别

  1. tinyint(1)还是选择tinyint(4)

情况

介绍

场景

tinyint(1) unsigned

可以存储0,1,2,3....9

使用boolean类映射:0映射为false,1-9映射为true只存储0和1,表示true或false,则使用tinyint(1)。

例如:业务字段中存在是否XX,即可这么设计

tinyint(4) unsigned zerofill

在一定范围内可以存储,只不过这里4代表显示4位,只有带zerofill 时,查询的时候会自动向左边补0。例如:

如果实际值是2,如果列指定了zerofill,查询结果就是0002,左边用0来填充

如果存储的数值有拓展,可以设置为tinyint(指定显示长度)。
例如:以后可能不仅仅是0和1,可能会存储其他数值的时候。这个时候留出一定拓展性。

三、列类型类型和表设计规范

  1. 列类型和Java类型转换:参考MySql官网

https://dev.mysql.com/doc/connector-j/5.1/en/connector-j-reference-type-conversions.html

  1. 表设计规约:参考阿里巴巴编码规约

  • 12
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值