重蔚自留地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

相关推荐

  • 重蔚自留地php学习第四十天——php操作数据库教程

    PHP操作mysql PHP要操作mysql,而mysql是c/s结构的软件,所以PHP需要充当一个客户端的角色。 PHP本身没有操作mysql数据库的能力,但是PHP提供了一个操作数据库的扩展。从而实现了PHP操作各种各样的数据库。   …

    2018年10月26日 PHP自学教程
    0353
  • 聊聊如何分析DB2数据库中pagesize和其对应寻址能力限制「db2 pagesize」。

    DB2数据库是一个强大的关系型数据库管理系统,它提供了许多高级特性和优化选项,pagesize是一个重要的参数,它决定了数据库在磁盘上的存储方式和性能,pagesize的大小直接影响了数据库的寻址能力,因为寻址能力是指…

    2024年6月16日
    01
  • 小编教你python 分组函数。

    在Python中,分组(grouping)是一种常见的数据处理操作,通常我们会使用pandas库中的groupby方法来实现数据的分组。groupby可以根据一个或多个键(可以是函数、数组或DataFrame列名)对数据进行分组。 基本用法 单…

    2024年7月25日
    01
  • 我来说说mysql删库。

    MySQL删库操作是指在MySQL数据库中删除一个或多个数据库,在执行此操作之前,请确保已经备份好相关数据,以防止误删,本文将介绍如何在MySQL中删除数据库,并提供一些建议和注意事项。 1. 使用DROP DATABASE语句删…

    2024年6月16日
    00
  • 教你甲骨文免费vps。

    【甲骨文免费vps】,这是一个非常有趣的话题,在这篇文章中,我将为您介绍什么是甲骨文免费VPS以及如何使用它。 什么是甲骨文?甲骨文是中国古代的一种文字,用于商代晚期至西周早期的卜辞、铭文等记录,它是中国历…

    2024年6月19日
    02
  • 今日分享如何把虚拟主机数据库数据清空掉。

    要清空虚拟主机数据库数据,首先需要登录到数据库管理系统,然后选择要清空的数据库,执行DELETE或TRUNCATE语句删除所有数据。具体操作方法因数据库类型而异。 清空虚拟主机数据库数据通常涉及以下步骤: 1、登录到…

    2024年6月29日
    01
  • 怎么启动mysql服务。

    一、MySQL简介 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司,MySQL是最流行的关系型数据库管理系统之一,在WEB应用方面,MySQL是最好的RDBMS(Relational Database Management Sy…

    2024年6月20日
    00
  • MySQL大表优化方案之引擎优化

    引擎 目前广泛使用的是MyISAM和InnoDB两种引擎: MyISAM MyISAM引擎是MySQL 5.1及之前版本的默认引擎,它的特点是: 不支持行锁,读取时对需要读到的所有表加锁,写入时则对表加排它锁 不支持事务 不支持外键 不支…

    2018年3月10日
    0215

联系我们

QQ:951076433

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