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

相关推荐

  • 说说html如何获取数据库的信息。

    HTML本身并不能直接获取数据库的信息,需要通过服务器端的编程语言(如PHP、Python、Java等)来连接数据库并获取数据,然后将数据传递给HTML页面进行展示,以下是使用PHP和MySQL数据库的示例: (图片来源网络,侵…

    2024年6月26日
    01
  • 今日分享WordPress优化:提升网站速度和用户体验。

    提升网站速度和用户体验是WordPress网站优化的重要目标,一个加载迅速且易于导航的网站可以显著提高用户满意度,减少跳出率,并有利于搜索引擎优化(SEO),以下是一些关键的WordPress优化策略: 1. 选择性能优秀的…

    2024年7月12日
    01
  • PHP实现数据库异地容灾故障恢复的方法。

    随着现代企业对信息化建设的重视程度越来越高,数据安全性和可靠性也成为了企业工作中至关重要的事项之一。一旦数据库出现故障,恢复数据需要耗费大量的时间和精力,而且在某些情况下,恢复效果并不理想。因此,数…

    2023年5月21日
    09
  • PHP与数据库队列的集成。

    随着现代Web应用的发展,越来越多的需要将任务异步处理,以提高网站的性能和用户体验。其中一种常见的方式是使用队列系统,将需要处理的任务排队,然后由后台进程异步处理。而PHP和数据库都是Web开发中广泛使用的工…

    2023年5月21日
    08
  • 关于mysql时间戳是什么意思。

    MySQL时间戳是一种数据类型,用于存储日期和时间信息。有两种形式:1、TIMESTAMP类型,占用4个字节的存储空间,存储的值会根据时区进行转换,存储为UTC,时间戳的值是可以自动更新的;2、DATETIME类型,占用8个字节…

    2024年7月27日
    01
  • 今日分享mysql删除库。

    MySQL删除库的方法有很多,这里我们介绍两种常见的方法:使用DROP DATABASE语句和使用mysqladmin命令。 一、使用DROP DATABASE语句 1. 语法 DROP DATABASE database_name; 2. 示例 假设我们要删除一个名为`testdb`…

    2024年6月18日
    04
  • 聊聊MySQL表的分类详解不同类型的表。

    MySQL是一种关系型数据库管理系统,它使用表来存储数据,在MySQL中,表可以分为不同的类型,每种类型都有其特定的用途和限制,本文将对MySQL中的不同类型的表进行详细的分类和解释。 (图片来源网络,侵删) 1、基…

    2024年6月20日
    00
  • 经验分享租用asp虚拟主机怎么搭建。

    什么是ASP虚拟主机? ASP虚拟主机,全称为Active Server Pages虚拟主机,是一种基于ASP技术的虚拟主机解决方案,它将一个物理服务器划分为多个逻辑服务器,每个逻辑服务器都可以运行独立的ASP程序,用户可以根据自…

    2024年7月22日
    06

联系我们

QQ:951076433

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