首页 > 数据库 >7:数据库设计思维-MySQL

7:数据库设计思维-MySQL

时间:2022-12-18 11:31:12浏览次数:50  
标签:思维 范式 +-------+---------------+------+-----+---------+-------+ int 数据库 eatery My

(目录)

7.1 数据库设计的基本概要

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

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

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第三范式:消除传递依赖

第三范式:

  • 例如成绩表,一般情况下不把总分列出来,只需要将成绩表中语数外相加就可以
  • 而高考成绩需要把总分数据列出来,根据具体项目需求确定是否消除传递依赖

标签:思维,范式,+-------+---------------+------+-----+---------+-------+,int,数据库,eatery,My
From: https://blog.51cto.com/yeatsliao/5950833

相关文章

  • mysql 8.0 递归实现菜单树
    mysql8.0递归实现菜单树WITHrecursiverec_menu(id,menu_id,sup_menu,menu_name,`level`,rownum,order_str)AS(SELECTT0.id,T0.menu_id,T0.sup_menu,T0.......
  • ADO.NET连接MySQL注意细节
    Nuget安装MySQL包MySql.Data.MySqlClient几个数据库对象的前缀为:MySQL比如:MySqlConnection连接字符串可以参考这里:https://www.cnblogs.com/cqpanda/p/16316311.......
  • DNA motif数据库
    一个核心的矛盾就是有motif的TF只占我们知道TF的一半不到,那自然在做分析的时候,很多motif就被忽略了,我在想能不能构建一个denovo的DNAmotif数据库,在分析数据时我们还能有......
  • 数据库问题总结
    OracleORA-00257:archivererrorConnectinternalonlyuntilfree数据库版本是:11.2.0.4.0使用Navicat连接Oracle数据库时,有问题,连接不上。看网上的提示......
  • MySQL
    MySQL及SQL注入如果您通过网页获取用户输入的数据并将其插入一个MySQL数据库,那么就有可能发生SQL注入安全的问题。本章节将为大家介绍如何防止SQL注入,并通过脚本来过滤S......
  • mysql数据库一些实用的东西
    -------------------------------数据库的锁粒度篇---------------------------------------------首先我们有一张数据表,三个字段id,name,age,val。id是主键,name是索引,info......
  • MySQL Workbench的安装
    1.下载MySQLWorkbench下载MySQLWorkbench2.安装步骤-下载MySQLWorkbench的msi包-安装过程-更改安装路径-安装成功-登录数据库-进入数据库-......
  • 数据库中的一些简单小问题
    1.常见SQL语句的执行顺序是怎样?(from,on,join,where,groupby,having,select,orderby,limit)2.MySQL服务端的常见组件有哪些?连接器,解析器,优化器,执行器3.MySQL中的InnoDB和MyISAM......
  • 6:列属性完整性-MySQL
    (目录)6.1列属性问题列属性要根据业务的要求来对数据的一些控制,例如是否能为空,是否是唯一的,等各种操作,就是我们每次desc表的时候的表头上的内容就是与类属性有关的东西:Ty......
  • mysql零基础-3
    第17章_触发器在实际开发中,我们经常会遇到这样的情况:有2个或者多个相互关联的表,如商品信息和库存信息分别存放在2个不同的数据表中,我们在添加一条新商品记录的......