编程一五八俱乐部SQL学习笔记-3-数据库的三大设计范式

一、第一范式1nf

数据表中的所有字段都是不可分割的原子值。

mysql> create table student2(
    -> id int primary key,
    -> name varchar(20),
    -> address varchar(30)
    -> );
mysql> insert into student2 values(1,'zhangsan','中国四川省成都市武侯区武侯大道100号');
mysql> insert into student2 values(2,'lisi','中国四川省成都市武侯区武侯大道200号');
mysql> insert into student2 values(3,'wangwu','中国四川省成都市高新区天府大道90号');
mysql> select * from student2;
+----+----------+-----------------------------------------------------+
| id | name     | address                                             |
+----+----------+-----------------------------------------------------+
|  1 | zhangsan | 中国四川省成都市武侯区武侯大道100|
|  2 | lisi     | 中国四川省成都市武侯区武侯大道200|
|  3 | wangwu   | 中国四川省成都市高新区天府大道90|
+----+----------+-----------------------------------------------------+
//其中address字段值可以继续拆分,不满足第一范式

mysql> create table student3( 
id int primary key, 
name varchar(20), 
country varchar(20), 
province varchar(20), 
city varchar(20),
details varchar(20));

mysql> insert into student3 value(1,'zhangsan','中国','四川省','成都市','武侯区武侯大道100号');
mysql> insert into student3 value(2,'lisi','中国','四川省','成都市','武侯区京城 大道200号');
mysql> insert into student3 value(3,'wangwu','中国','四川省','成都市','高新 区天府大 90号');
mysql> select * from student3;
+----+----------+---------+-----------+-----------+-----------------------------+
| id | name     | country | province  | city      | details                     |
+----+----------+---------+-----------+-----------+-----------------------------+
|  1 | zhangsan | 中国    | 四川省    | 成都市    | 武侯区武侯大道100|
|  2 | lisi     | 中国    | 四川省    | 成都市    | 武侯区京城大道200|
|  3 | wangwu   | 中国    | 四川省    | 成都市    | 高新区天府大道90|
+----+----------+---------+-----------+-----------+-----------------------------+

范式设计越详细,对某些实际操作可能更好,党并非有好处,需要根据项目实际情况设定。

二、第二范式2nf

满足第一范式的前提下,其他列都必须完全依赖于主键列。
如果出现不完全依赖,只可能发生在联合主键的情况下。

-- 订单表
CREATE TABLE myorder (
    product_id INT,
    customer_id INT,
    product_name VARCHAR(20),  //只和product_id有关,与主键里的customer_id无关
    customer_name VARCHAR(20), //只和customer_id有关,与主键里的product_id无关
    PRIMARY KEY (product_id, customer_id) 
);

这就不满足第二范式:其他列都必须完全依赖于主键列!

CREATE TABLE myorder (
    order_id INT PRIMARY KEY,
    product_id INT,
    customer_id INT
);

CREATE TABLE product (
    id INT PRIMARY KEY,
    name VARCHAR(20)
);

CREATE TABLE customer (
    id INT PRIMARY KEY,
    name VARCHAR(20)
);

myorder 表中:product_idcustomer_id完全依赖于 order_id 主键。
productcustomer 表中:其他字段又完全依赖于相应的主键。
满足了第二范式的设计!

三、第三范式3nf

在满足第二范式的前提下,除了主键列之外,其他列之间不能有传递依赖关系。

CREATE TABLE myorder (
    order_id INT PRIMARY KEY,
    product_id INT,
    customer_id INT,
    customer_phone VARCHAR(15)
);

表中的 customer_phone 有可能依赖于customer_id ,即客户的手机号依赖于客户的编号,也就不满足了第三范式的设计:其他列之间不能有传递依赖关系。

CREATE TABLE myorder (
    order_id INT PRIMARY KEY,
    product_id INT,
    customer_id INT
); //其他列只依赖于主键列,列之间没有相互依赖关系
CREATE TABLE customer (
    id INT PRIMARY KEY,
    name VARCHAR(20),
    phone VARCHAR(15)
); //其他列只依赖于主键列,相互列之间没有依赖关系

修改后就不存在其他列之间的传递依赖关系,其他列都只依赖于主键列,满足了第三范式的设计!

成长于苍茫茫的异乡,回首依然望见故乡月亮。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值