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

相关推荐

  • 分享asp+mysql。

    ASP和MySQL是两种常用的Web开发技术,ASP用于编写动态网页,而MySQL则是一种关系型数据库管理系统。 强大的ASPCMS使用MySQL数据库 简介 ASPCMS(Active Server Pages Content Management System)是一个基于ASP.NET…

    2024年6月26日
    01
  • 关于oracle 导出指定表数据。

    Oracle导出指定表数据,可以使用expdp命令行工具。 Oracle数据库是一种广泛使用的企业级关系型数据库管理系统,它提供了丰富的功能和灵活的操作方式,在日常工作中,我们可能需要将数据库中的数据导出到其他格式,…

    2024年7月13日
    01
  • 我来说说如何在centos7上搭建mysql主从服务器。

    背景介绍 MySQL主从服务器是一种常见的数据库备份和读写分离方案,在这种架构中,一个服务器作为主服务器(Master),负责处理写操作,而其他服务器作为从服务器(Slave),负责处理读操作,主服务器将数据变更记录到二进…

    2024年7月2日
    02
  • 我来分享mysql如何卸载干净。

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

    2024年6月19日
    01
  • 我来教你jdbc加载数据库驱动程序的方法有哪些。

    JDBC加载数据库驱动程序的方法主要有以下几种:需要在Java项目中导入JDBC相关的库文件,一般是将JDBC驱动程序的jar包添加到项目的类路径中。可以使用Class.forName()方法来加载数据库驱动程序,如MySQL的驱动程序是…

    2024年7月28日
    04
  • 经验分享MySQL轻松实现无排序分页。

    在MySQL中,我们经常需要对查询结果进行分页,通常情况下,我们会使用LIMIT和OFFSET关键字来实现这个功能,这种方法有一个问题,那就是如果数据量非常大,排序操作可能会非常耗时,有没有一种方法可以在不排序的情…

    2024年6月20日
    01
  • 经验分享mysql一行数据长度限制。

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

    2024年6月20日
    02
  • 小编分享利用MySQL实现一行转换多行的技巧。

    在MySQL中,有时候我们需要将一行数据转换为多行数据,这种情况通常发生在需要对某个字段的值进行拆分的时候,我们有一个包含地址信息的表,每个地址信息都存储在一个字段中,现在需要将这些地址信息拆分成多个行,…

    2024年6月20日
    00

联系我们

QQ:951076433

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