7:数据库设计思维-MySQL

举报
Yeats_Liao 发表于 2022/10/23 21:35:38 2022/10/23
【摘要】 7.1 数据库设计的基本概要表结构就是定义数据表文件名,确定数据表包含哪些字段,各字段的字段名、字段类型、及宽度,并将这些数据输入到计算机当中关系型数据库:两张表的共有字段去确定数据的完整性行(实体):一条数据记录列(属性):一个字段数据冗余:有的数据没有必要设计,但还是设计了,指一模一样的数据存储多于一份的情况优点是提高查询性能,缺点是数据太多重复,成本高冗余只能通过分表减少,不可能杜绝...

7.1 数据库设计的基本概要

表结构就是定义数据表文件名,确定数据表包含哪些字段,各字段的字段名、字段类型、及宽度,并将这些数据输入到计算机当中

  • 关系型数据库:两张表的共有字段去确定数据的完整性
  • 行(实体):一条数据记录
  • 列(属性):一个字段
  • 数据冗余:有的数据没有必要设计,但还是设计了,指一模一样的数据存储多于一份的情况
  • 优点是提高查询性能,缺点是数据太多重复,成本高
  • 冗余只能通过分表减少,不可能杜绝
describedesc)表名

desc 是describe的缩写,用于查看特定表的详细设计信息

show columns from 表名 

查询出表的列信息

show create table 表名

查询建表语句

mysql> desc eatery;
+-------+---------------+------+-----+---------+-------+
| Field | Type          | Null | Key | Default | Extra |
+-------+---------------+------+-----+---------+-------+
| id    | int(20)       | NO   | PRI | NULL    |       |
| money | decimal(10,4) | YES  |     | NULL    |       |
| stuId | int(4)        | YES  | MUL | NULL    |       |
+-------+---------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> show columns from eatery;
+-------+---------------+------+-----+---------+-------+
| Field | Type          | Null | Key | Default | Extra |
+-------+---------------+------+-----+---------+-------+
| id    | int(20)       | NO   | PRI | NULL    |       |
| money | decimal(10,4) | YES  |     | NULL    |       |
| stuId | int(4)        | YES  | MUL | NULL    |       |
+-------+---------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> show create table eatery;
+--------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table  | Create Table



                                       |
+--------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| eatery | CREATE TABLE `eatery` (
  `id` int(20) NOT NULL,
  `money` decimal(10,4) DEFAULT NULL,
  `stuId` int(4) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `stuId` (`stuId`),
  CONSTRAINT `eatery_ibfk_1` FOREIGN KEY (`stuId`) REFERENCES `stu` (`stuId`) ON DELETE SET NULL ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=gbk |
+--------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

7.2 实体和实体之间的关系

数据对象彼此之间相互连接的方式称为 联系(Relationship),也称为关系,联系可分为以下 3 种类型

  • 一对一联系 (1 ∶ 1) 例如,部门与经理的联系是一对一的
  • 一对多联系 (1 ∶ N) 例如,某校教师与教的课程之间存在一对多的
  • 多对多联系 (M ∶ N) 例如,学生与课程间的联系是多对多的

7.3 Codd第一范式:确保每列原子

关系数据库中的关系必须满足一定的要求,即满足不同的范式

引用百度的图这里是引用

第一范式:

  • 确保每一个字段的数据不能再分了:确保每个字段的原子性
  • 例如一条时间数据:2018-2019
  • 这里应该将其拆开成两个数据,开始时间2018,结束时间2019

7.4 Codd第二范式:非键字段必须依赖与键字段

第二范式:

  • 一个表只描述一件事情,不能扯淡
  • 比如学生表就放学生的信息,不放工资数据,没关系的信息就别放在一张表

7.5 Codd第三范式:消除传递依赖

第三范式:

  • 例如成绩表,一般情况下不把总分列出来,只需要将成绩表中语数外相加就可以
  • 而高考成绩需要把总分数据列出来,根据具体项目需求确定是否消除传递依赖
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。