重蔚自留地php学习第三十七天——mysql数据库范式的总结

关系:一对多,多对一,多对多,一对一

范式Normal Format

第一范式:原子性,字段不可再分割

第二范式:取消部分依赖,不使用复合主键,通常设计时使用逻辑主键

第三范式:取消传递依赖,将不同的实体创建不同表,需要使用实体关系的时候,使用对应的主键。

为了提高效率,会在设计数据表的时候刻意增加适当的数据冗余。逆规范化(效率与磁盘空间的对抗)。

外键foreign key

创建外键

创建表:foreign key(字段) references 表名(字段)

修改表:alter table 表名 add constraint 外键名 foreign key (字段) references 表名(字段)

外键约束:

子表不能插入父表不存在的数据

父表不能删除子表已经有指向的数据

外键约束模式

严格模式:restrict(默认的)

置空模式:set null

级联模式:cascade

foreign key(字段) references 表名(字段) on update 模式[cascade] on delete 模式[set null]

删除外键:alter table 表名 drop foreign key 外键名

高级数据操作

增加:蠕虫复制,主键重复(on duplicate key,replace)

删除:搭配order by和limit,truncate(充值表)

修改:搭配order by和limit

查询:select [select选项] 字段列表/表达式 [from子句] [where子句] [group by子句] [having 子句] [order by子句] [limit 子句]

字段和表名使用别名

where子句:运算结果通常是一个布尔结果,比较运算符和逻辑运算符

group by子句:分组统计

count:统计记录数,统计不为空的字段

max

min

avg

sum

多分组:group by 字段列表

回溯统计

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/10370.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2018年10月16日 00:00
下一篇 2018年10月17日 09:49

相关推荐

  • 今日分享python序列求和函数。

    在Python中,序列求和是一个常见的操作,序列指的是一系列按顺序排列的元素,可以是列表、元组或其他可迭代对象,求和即计算这些元素的总和,下面详细介绍Python中如何对序列进行求和。 使用内置函数sum() Python提…

    2024年7月24日
    03
  • MYSQL涉及的英语单词!

    sql: struct query language mysql: host:主机 user:用户 password:密码 data:数据 database:数据库 table:表 column:列 field:列 row:行 port:端口 quit:取消,退出 exit:退出 charset:字符集,字符编…

    2018年4月30日
    0735
  • 我来说说linux查看mysql安装路径。

    在Linux系统中,查看MySQL安装路径的方法有很多种,这里我们介绍一种常用的方法:使用`which`命令和`find`命令组合查找。 我们可以使用`which`命令查找MySQL的可执行文件路径,在终端中输入以下命令: which mysql …

    2024年6月20日
    03
  • 我来教你深入浅出Oracle中的物理表。

    Oracle中的物理表是指存储在磁盘上的数据库对象,由数据块组成,包含行和列,用于持久化存储数据。物理表结构由段、区、盘区构成,支持索引以加速查询。 深入浅出Oracle中的物理表 在Oracle数据库中,物理表是存储…

    2024年6月26日
    01
  • 不限流量云vps租用怎么加速。

    要加速不限流量云VPS的租用,可以尝试以下方法:1.选择合适的地理位置:选择离您所在地区较近的服务器位置,可以减少网络延迟,提高访问速度。2.使用CDN加速:CDN是一种内容分发网络,可以将您的网站内容缓存到全球…

    2024年7月17日
    04
  • 经验分享mysql一行数据长度限制。

    MySQL是一种关系型数据库管理系统,它使用表格来存储数据,在MySQL中,一行被称为记录,一列被称为字段,下面我们将详细介绍MySQL中的行和列。 (图片来源网络,侵删) 1、行(Record) 在MySQL中,行是一张表中的…

    2024年6月20日
    02
  • 我来分享怎么创建个sql数据库,sql创建数据库语句的方法。

    在计算机科学中,SQL(结构化查询语言)是一种用于管理关系数据库的编程语言,它可以用于创建、查询、更新和删除数据库中的数据,本文将详细介绍如何使用SQL创建数据库以及相关的语句。 我们需要了解什么是数据库,数…

    2024年6月19日
    04
  • 教你如何安装redis数据库。

    Redis-dump 是一个用于备份和还原 Redis 数据库的工具,以下是如何安装 redis-dump 的详细步骤: 1、检查系统环境 在开始之前,确保你的系统满足以下条件: 安装了 Redis。 安装了 Node.js,redis-dump 是一个 Node…

    2024年7月14日
    03

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息