重蔚自留地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+MySQL实现在线测试答题示例

    这个实例主要给大家介绍如何使用jQuery+PHP+MySQL来实现在线测试题,包括动态读取题目,答题完毕后台评分,并返回答题结果。读取答题列表:$sql = "select * from quiz order by id asc"; $query = mysql…

    2022年6月18日
    0146
  • PHP实现数据库主从复制的方法。

    随着业务的不断发展和业务量的不断增加,单个数据库的性能往往难以满足需求,因此数据库集群成为了一个非常重要的方向。在数据库集群中,主从复制是一个非常常见且重要的技术,通过主从复制可以将主数据库中的数据…

    2023年5月21日
    010
  • 说说discuz搭建教程。

    Discuz是一款十分流行的搭建论坛的工具,占有很大的市场份额,你无需会代码即可搭建一个专属论坛,并且Discuz也拥有许多插件和应用可以丰富你的论坛功能。 Discuz3.4怎么搭建站点 Discuz!是一款功能强大的开源社区…

    2024年7月8日
    03
  • 今日分享虚拟主机空间租用怎么选择。

    选择虚拟主机空间租用时,首先需要了解空间主机的类型并选择合适的操作系统。关注带宽和流量限制,考虑技术支持和服务的可靠性。比较价格和性价比,同时关注扩展性和维护成本。查看用户评价和口碑也是一个好的选择…

    2024年7月8日
    01
  • asp虚拟主机管理的方法有哪些。

    ASP虚拟主机的管理方法主要包括利用控制面板、FTP、数据库管理工具和文件管理器等工具进行操作。控制面板是最常使用的方式,可以方便地进行各种网站设置的管理;FTP和API则适合有一定技术水平的用户和开发者,便于…

    2024年7月14日
    01
  • oracle怎么往表里插数据。

    Oracle往表中插入数据,可以使用INSERT语句。 Oracle数据库是一种广泛应用于企业级应用的数据库管理系统,它具有强大的数据处理能力和丰富的功能,在日常工作中,我们经常需要往Oracle表里插入数据,本文将详细介绍…

    2024年7月14日
    02
  • 我来教你MySQL报错:Error 1045(28000)的解决方法。

    简单介绍一下MySQL报错:Error 1045(28000) : user ‘root’@‘localhost’is denied access的解决方法: 服务启动之后,执行mysql -u root -p 报错:Error 1045(28000) : user ‘root’@‘localhost’is denied access Err…

    2024年6月13日
    01
  • 云服务器租用怎么安装数据库。

    当您在云服务器上租用数据库服务时,有多种选择。您可以选择MySQL这种开放源代码的关系型数据库管理系统(RDBMS),它使用最常用的数据库管理语言—结构化查询语言(SQL)进行数据库管理。另一种选择是腾讯云数据库M…

    2024年7月18日
    01

联系我们

QQ:951076433

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