数据库应用-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

相关文章

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

Redis中Stream详解及应用小结

《Redis中Stream详解及应用小结》RedisStreams是Redis5.0引入的新功能,提供了一种类似于传统消息队列的机制,但具有更高的灵活性和可扩展性,本文给大家介绍Redis中Strea... 目录1. Redis Stream 概述2. Redis Stream 的基本操作2.1. XADD

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1