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

相关推荐

  • mysql的数据操作_修改数据

    语句:update 表名 set 字段名1=值表达式1,字段名2=值表达式2,....where条件 ; 之前相关数据库操作请移步: 1、数据库的删、查、改操作 2、mysql的数据操作_修改数据和查询数据 3、mysql的数据操作_插入数据 4、…

    2018年3月11日
    0226
  • 小编教你jdbc怎么向数据库添加数据。

    要使用JDBC向数据库添加数据,首先需要建立连接,然后创建一个Statement对象,通过该对象执行SQL插入语句。以下是一个简单的示例:,,“java,import java.sql.Connection;,import java.sql.DriverManager;…

    2024年7月19日
    00
  • 我来分享审计日志系统的基本功能有哪些。

    审计日志系统的基本功能包括:记录操作行为、监控异常事件、分析安全风险、生成报告等。 (图片来源网络,侵删) 审计日志系统是企业信息系统中的一个重要组成部分,它的主要功能是记录和追踪系统中的所有操作活动…

    2024年6月30日
    00
  • 经验分享mysql分割数据的方式有哪些方法。

    在MySQL中,分割数据通常指的是将一个数据库、表或者表中的数据拆分成多个部分,这种操作可以用于多种目的,比如改善性能、简化管理、实现数据分布等,以下是几种常见的MySQL数据分割方式: (图片来源网络,侵删)…

    2024年6月18日
    00
  • 关于Alma Linux支持哪些数据库系统。

    Alma Linux 支持的数据库系统 (图片来源网络,侵删) Alma Linux,作为一款基于 RHEL (Red Hat Enterprise Linux) 构建的开源企业级操作系统,提供了对多种数据库系统的原生支持,以下是一些在 Alma Linux 上广泛…

    2024年6月26日
    00
  • 我来说说mysql数据库锁表怎么解决的。

    MySQL数据库锁表问题通常是由于多个事务竞争同一资源导致的,当一个事务获取了某个数据行的锁,其他事务就必须等待直到该行锁被释放,在某些情况下,这可能导致锁表现象,即整个表被锁定,其他事务无法访问表中的任…

    2024年7月13日
    01
  • 小编教你ubuntu启动mysql。

    在Ubuntu系统中,启动MySQL数据库服务器非常简单,下面我将详细解释如何进行操作。 我们需要确保已经安装了MySQL,如果还未安装,可以通过以下命令进行安装: sudo apt-get update sudo apt-get install mysql-serv…

    2024年6月16日
    00
  • 经验分享mysql服务器安装步骤是什么样的。

    MySQL服务器安装步骤如下:1. 下载MySQL安装包;2. 解压缩安装包;3. 进入解压后的文件夹,运行mysqld –initialize命令进行初始化;4. 进入解压后的文件夹,运行mysqld命令启动MySQL服务;5. 进入解压后的文…

    2024年7月27日
    00

联系我们

QQ:951076433

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