数据库应用-NF^2 Modell(Non First Normal Form)

2024-03-26 12:48

本文主要是介绍数据库应用-NF^2 Modell(Non First Normal Form),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关系数据模型一方面很简单,直观,但另一方面它的表现力也因此受到限制。
它的属性与值之间不具备结构化关系。//是指不能属性嵌套吗??

1NF(erst Normalform)

1NF的要求是:关系的所有属性都是原子属性(Alle Attributwerte atomar)

NF2Modell

NF2modell 就是嵌套关系模型(geschachtelte Relationen)
嵌套关系刚好与1NF规则相反,他包含以下两层意思:
1.一个属性可以是另外一个属性的一员
2.属性值本身可以是另外一个关系
//只会输入一般图表,含嵌套属性的图表不知道怎么输入,就先跳了
NF2Modell 有更强的表现力,但相对的它的定义的难度也同时增加了

Schema

Schema就是一连串的属性(Schema ist Liste von Attributen)
每一个属性都有各自的值域
元组(Tupel)就是用来表示值的向量
R=(A1,...,An)AiU,1in:dom(R)=dom(A1)...dom(An)
R=(A1,...,An,R1,...,Rn):
dom(R)=dom(A1)...dom(An)2dom(R1)...2dom(Rn) //???
//U是何物至今未明??
问题:顺序决定值的意义
比如有两个R
R1=(Vorname,Nachname)
R2=(Nachname,Vorname)
当我们拿到一个Tupel(Stephan,Heinrich)时并不能很好的区分出姓和名
换句话说,我们能够把Tupel写得很模糊

Algebra of NF2

包括两部分:
1.与relation algebra相似的operation
//虽然作用相同,但在具体实施上差别还是很大的,比如projection一个内部属性
2.一些特有的operation,如:Nest,Unnest
nest就是生成子属性,比如 nB=(C,D)(r) 就表示把C和D作为B的子属性

A11122C11122D34433E33434

但应注意当其他属性值相同的项会发生合并,例如上表nest操作后B的一个值是(1,3,1,4)而不是(1,3)。换句话当使用操作 :σB=(1,4)(r1) 时,不能获得第一个项
另外nest的顺序不同,得到的结果也可能不同
unnest与nest的作用刚好相反,但是并非所有nest都是可逆的,比如
A11BC111D344

当他使用unnest时因为重复最终结果只剩下两项
我们把上面情况归为非PNF(Partitioned Normal Form)
从上面我们也可以知道光看Schema得话是没法分辨一个Relation是不是PNF

PNF(Partitioned Normal Form)

定义PNF:

这篇关于数据库应用-NF^2 Modell(Non First Normal Form)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/848557

相关文章

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

IDEA如何切换数据库版本mysql5或mysql8

《IDEA如何切换数据库版本mysql5或mysql8》本文介绍了如何将IntelliJIDEA从MySQL5切换到MySQL8的详细步骤,包括下载MySQL8、安装、配置、停止旧服务、启动新服务以及... 目录问题描述解决方案第一步第二步第三步第四步第五步总结问题描述最近想开发一个新应用,想使用mysq

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Java读取InfluxDB数据库的方法详解

《Java读取InfluxDB数据库的方法详解》本文介绍基于Java语言,读取InfluxDB数据库的方法,包括读取InfluxDB的所有数据库,以及指定数据库中的measurement、field、... 首先,创建一个Java项目,用于撰写代码。接下来,配置所需要的依赖;这里我们就选择可用于与Infl

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora