php教程 php手册 数据库设计范式

数据库设计范式

Jun 21, 2016 am 09:07 AM
location sno

设计|数据|数据库|数据库设计

关系数据库设计之时是要遵守一定的规则的。尤其是数据库设计范式 现简单介绍1NF(第一范式),2NF(第二范式),3NF(第三范式)和BCNF,另有第四范式和第五范式留到以后再介绍。 在你设计数据库之时,若能符合这几个范式,你就是数据库设计的高手。

第一范式(1NF):在关系模式R中的每一个具体关系r中,如果每个属性值 都是不可再分的最小数据单位,则称R是第一范式的关系。例:如职工号,姓名,电话号码组成一个表(一个人可能有一个办公室电话 和一个家里电话号码) 规范成为1NF有三种方法:
一是重复存储职工号和姓名。这样,关键字只能是电话号码。
二是职工号为关键字,电话号码分为单位电话和住宅电话两个属性
三是职工号为关键字,但强制每条记录只能有一个电话号码。
以上三个方法,第一种方法最不可取,按实际情况选取后两种情况。

第二范式(2NF):如果关系模式R(U,F)中的所有非主属性都完全依赖于任意一个候选关键字,则称关系R 是属于第二范式的。
例:选课关系 SCI(SNO,CNO,GRADE,CREDIT)其中SNO为学号, CNO为课程号,GRADEGE 为成绩,CREDIT 为学分。 由以上条件,关键字为组合关键字(SNO,CNO)
在应用中使用以上关系模式有以下问题:
a.数据冗余,假设同一门课由40个学生选修,学分就 重复40次。
b.更新异常,若调整了某课程的学分,相应的元组CREDIT值都要更新,有可能会出现同一门课学分不同。
c.插入异常,如计划开新课,由于没人选修,没有学号关键字,只能等有人选修才能把课程和学分存入。
d.删除异常,若学生已经结业,从当前数据库删除选修记录。某些门课程新生尚未选修,则此门课程及学分记录无法保存。
原因:非关键字属性CREDIT仅函数依赖于CNO,也就是CREDIT部分依赖组合关键字(SNO,CNO)而不是完全依赖。
解决方法:分成两个关系模式 SC1(SNO,CNO,GRADE),C2(CNO,CREDIT)。新关系包括两个关系模式,它们之间通过SC1中的外关键字CNO相联系,需要时再进行自然联接,恢复了原来的关系

第三范式(3NF):如果关系模式R(U,F)中的所有非主属性对任何候选关键字都不存在传递信赖,则称关系R是属于第三范式的。
例:如S1(SNO,SNAME,DNO,DNAME,LOCATION) 各属性分别代表学号,
姓名,所在系,系名称,系地址。
关键字SNO决定各个属性。由于是单个关键字,没有部分依赖的问题,肯定是2NF。但这关系肯定有大量的冗余,有关学生所在的几个属性DNO,DNAME,LOCATION将重复存储,插入,删除和修改时也将产生类似以上例的情况。
原因:关系中存在传递依赖造成的。即SNO -> DNO。 而DNO -> SNO却不存在,DNO -> LOCATION, 因此关键辽 SNO 对 LOCATION 函数决定是通过传递依赖 SNO -> LOCATION 实现的。也就是说,SNO不直接决定非主属性LOCATION。
解决目地:每个关系模式中不能留有传递依赖。
解决方法:分为两个关系 S(SNO,SNAME,DNO),D(DNO,DNAME,LOCATION)
注意:关系S中不能没有外关键字DNO。否则两个关系之间失去联系。

BCNF:如果关系模式R(U,F)的所有属性(包括主属性和非主属性)都不传递依赖于R的任何候选关键字,那么称关系R是属于BCNF的。或是关系模式R,如果每个决定因素都包含关键字(而不是被关键字所包含),则RCNF的关系模式。
例:配件管理关系模式 WPE(WNO,PNO,ENO,QNT)分别表仓库号,配件号,职工号,数量。有以下条件
a.一个仓库有多个职工。
b.一个职工仅在一个仓库工作。
c.每个仓库里一种型号的配件由专人负责,但一个人可以管理几种配件。
d.同一种型号的配件可以分放在几个仓库中。
分析:由以上得 PNO 不能确定QNT,由组合属性(WNO,PNO)来决定,存在函数依赖(WNO,PNO) -> ENO。由于每个仓库里的一种配件由专人负责,而一个人可以管理几种配件,所以有组合属性(WNO,PNO)才能确定负责人,有(WNO,PNO)-> ENO。因为 一个职工仅在一个仓库工作,有ENO -> WNO。由于每个仓库里的一种配件由专人负责,而一个职工仅在一个仓库工作,有 (ENO,PNO)-> QNT。
找一下候选关键字,因为(WNO,PNO) -> QNT,(WNO,PNO)-> ENO ,因此 (WNO,PNO)可以决定整个元组,是一个候选关键字。根据ENO->WNO,(ENO,PNO)->QNT,故(ENO,PNO)也能决定整个元组,为另一个候选关键字。属性ENO,WNO,PNO 均为主属性,只有一个非主属性QNT。它对任何一个候选关键字都是完全函数依赖的,并且是直接依赖,所以该关系模式是3NF。
分析一下主属性。因为ENO->WNO,主属性ENO是WNO的决定因素,但是它本身不是关键字,只是组合关键字的一部分。这就造成主属性WNO对另外一个候选关键字(ENO,PNO)的部 分依赖,因为(ENO,PNO)-> ENO但反过来不成立,而P->WNO,故(ENO,PNO)-> WNO 也是传递依赖。
虽然没有非主属性对候选关键辽的传递依赖,但存在主属性对候选关键字的传递依赖,同样也会带来麻烦。如一个新职工分配到仓库工作,但暂时处于实习阶段,没有独立负责对某些配件的管理任务。由于缺少关键字的一部分PNO而无法插入到该关系中去。又如某个人改成不管配件了去负责安全,则在删除配件的同时该职工也会被删除。
解决办法:分成管理EP(ENO,PNO,QNT),关键字是(ENO,PNO)工作EW(ENO,WNO)其关键字是ENO
缺点:分解后函数依赖的保持性较差。如此例中,由于分解,函数依赖(WNO,PNO)-> ENO 丢失了, 因而对原来的语义有所破坏。没有体现出每个仓库里一种部件由专人负责。有可能出现 一部件由两个人或两个以上的人来同时管理。因此,分解之后的关系模式降低了部分完整性约束。

一个关系分解成多个关系,要使得分解有意义,起码的要求是分解后不丢失原来的信息。这些信息不仅包括数据本身,而且包括由函数依赖所表示的数据之间的相互制约。进行分解的目标是达到更高一级的规范化程度,但是分解的同时必须考虑两个问题:无损联接性和保持函数依赖。有时往往不可能做到既有无损联接性,又完全保持函数依赖。需要根据需要进行权衡。

1NF直到BCNF的四种范式之间有如下关系:
BCNF包含了3NF包含2NF包含1NF

小结:
目地:规范化目的是使结构更合理,消除存储异常,使数据冗余尽量小,便于插入、删除和更新
原则:遵从概念单一化 "一事一地"原则,即一个关系模式描述一个实体或实体间的一种联系。规范的实质就是概念的单一化。
方法:将关系模式投影分解成两个或两个以上的关系模式。
要求:分解后的关系模式集合应当与原关系模式"等价",即经过自然联接可以恢复原关系而不丢失信息,并保持属性间合理的联系。

注意:一个关系模式结这分解可以得到不同关系模式集合,也就是说分解方法不是唯一的。最小冗余的要求必须以分解后的数据库能够表达原来数据库所有信息为前提来实现。其根本目标是节省存储空间,避免数据不一致性,提高对关系的操作效率,同时满足应用需求。实际上,并不一定要求全部模式都达到BCNF不可。有时故意保留部分冗余可能更方便数据查询。尤其对于那些更新频度不高,查询频度极高的数据库系统更是如此。

在关系数据库中,除了函数依赖之外还有多值依赖,联接依赖的问题,从而提出了第四范式,第五范式等更高一级的规范化要求。在此,以后再谈。

各位朋友,你看过后有何感想,其实,任何一本数据库基础理论的书都会讲这些东西,考虑到很多网友是半途出家,来做数据库。特找一本书大抄特抄一把,各位有什么问题,也别问我了,自已去找一本关系数据库理论的书去看吧,说不定,对各位大有帮助。说是说以上是基础理论的东西,请大家想想,你在做数据库设计的时候有没有考虑过遵过以上几个范式呢,有没有在数据库设计做得不好之时,想一想,对比以上所讲,到底是违反了第几个范式呢?
我见过的数据库设计,很少有人做到很符合以上几个范式的,一般说来,第一范式大家都可以遵守,完全遵守第二第三范式的人很少了,遵守的人一定就是设计数据库的高手了,BCNF的范式出现机会较少,而且会破坏完整性,你可以在做设计之时不考虑它,当然在ORACLE中可通过触发器解决其缺点。以后我们共同做设计之时,也希望大家遵守以上几个范式。



본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

데이터베이스에서 sno의 약어는 무엇입니까? 데이터베이스에서 sno의 약어는 무엇입니까? Mar 10, 2023 pm 02:05 PM

데이터베이스에서 sno는 "student number"의 약어, "cno"는 과목번호의 약어, "sdept"는 학과명 약어, "cpno"는 선수과목의 약어, "ccredit"는 교과목의 약어이다. 크레딧의 약어로, 데이터베이스는 데이터 구조에 따라 구성됩니다. 데이터를 저장하고 관리하는 창고는 컴퓨터에 장기간 저장되는 대량의 데이터를 정리하고 공유 가능하며 통합 관리하는 것입니다.

Nginx 서버의 위치 구성 예시 분석 Nginx 서버의 위치 구성 예시 분석 May 24, 2023 pm 02:05 PM

먼저 nginxwiki의 예를 예로 들어 위치 유형과 일치 규칙을 간략하게 소개하겠습니다. .[ 구성b]}위치^~/im

nginx 위치에서 uri를 가로채는 방법 nginx 위치에서 uri를 가로채는 방법 May 18, 2023 pm 12:07 PM

참고: location의 루트 및 aliasroot 명령은 검색 루트를 루트가 설정한 디렉터리로 설정합니다. 즉, uri는 잘리지 않습니다. 대신 원본 uri는 파일을 찾기 위해 해당 디렉터리로 이동하는 데 사용됩니다. aias 명령은 일치하는 uri를 잘라낸 다음 별칭으로 설정된 경로와 나머지 uri를 하위 경로로 사용하여 해당 위치에서 Proxy_pass의 uri를 찾습니다. /"이면 일치하는 URI가 잘립니다. 꼬리가 "/"가 아닌 경우 Proxy_pass의 URL에 uri가 포함되어 있으면 일치하는 URI가 잘리지 않습니다.

Nginx에서 위치를 구성하고 규칙을 다시 작성하는 방법 Nginx에서 위치를 구성하고 규칙을 다시 작성하는 방법 May 18, 2023 pm 12:25 PM

위치 튜토리얼 예: location=/{#정확한 일치/, 호스트 이름 뒤에는 어떤 문자열도 올 수 없습니다. [configurationA]}location/{#모든 주소가 /로 시작하기 때문에 이 규칙은 모든 요청과 일치합니다#그러나 일반 및 가장 긴 문자열 먼저 [configurationB]}location/documents/{#/documents/로 시작하는 모든 주소와 일치합니다. 일치 후 계속 아래쪽으로 검색합니다.#다음 정규식이 일치하지 않는 경우에만 이 문서에서는 [configurationC]}location을 사용합니다. ~/문서

Nginx에서 서버와 위치의 일치 논리는 무엇입니까? Nginx에서 서버와 위치의 일치 논리는 무엇입니까? May 12, 2023 am 11:10 AM

서버 일치 논리 nginx는 요청을 실행할 서버 블록을 결정할 때 주로 서버 블록의 청취 및 server_name 필드에 중점을 둡니다. 청취 명령 청취 필드는 청취 필드가 명시적으로 지정되지 않은 경우 서버 응답의 IP 및 포트를 정의합니다. 구성된 경우 기본 수신 0.0.0.0:80(루트) 또는 0.0.0.0:8080(비루트) 수신은 다음과 같이 구성될 수 있습니다. IP와 포트의 조합, 단일 IP, 기본적으로 포트 80에서 수신, 단일 포트 및 기본적으로 모든 IP 인터페이스에서 수신 대기 마지막 항목은 일반적으로 다른 인터페이스에서만 사용되는 unixsocket 경로

Nginx 서버에서 위치를 구성하는 방법 Nginx 서버에서 위치를 구성하는 방법 May 14, 2023 pm 07:16 PM

문법 위치[=|~|~*|^~]/uri/{...} 규칙=: 정확한 uri 일치를 나타냅니다(관심 있는 학생들은 url과 uri의 차이를 살펴볼 수 있습니다)~: 대소문자를 구분함을 나타냅니다. 정규 일치~*: 대소문자를 구분하지 않는 일반 일치를 나타냅니다!~&&!~*: 대소문자를 구분하지 않음을 나타냅니다. 일치하지 않음 일반 및 대소문자를 구분하지 않고 일치하지 않음 일반 /: 범용 일치, 모든 요청은 위치 일치와 일치합니다 대상 위치 일치 테스트에서는 매개변수 부분이 아닌 요청 uri 부분만 사용합니다. (이유: 매개변수를 쓰는 방법이 너무 많아 정확하게 일치시킬 수 없습니다.) 위치 일치 시퀀스에서 여러 위치 구성을 전제로,

Nginx 위치 지시어 URI 일치 규칙은 무엇입니까? Nginx 위치 지시어 URI 일치 규칙은 무엇입니까? May 14, 2023 pm 11:58 PM

1. 소개 위치 지시문은 사전 정의된 URL 일치 규칙에 따라 사용자가 보낸 요청을 수신하고 일치 결과를 기반으로 요청을 백엔드 서버로 전달하여 거부하고 반환합니다. 403. 404, 500 오류 처리 등 2. 위치 명령 구문 location[=|~|~*|^~|@]/uri/{…} 또는 location@name{…} 3. URI 일치 모드 위치 명령은 두 가지 일치 모드로 구분됩니다. 1> 일반 문자 문자열 일치: =로 시작하거나 선행 문자(~) 없이 시작하는 규칙 2> 일반 일치: ~ 또는 ~*로 시작하는 것은 일반 일치를 나타내고, ~*

nginx 위치와 Proxy_pass의 차이점은 무엇입니까 nginx 위치와 Proxy_pass의 차이점은 무엇입니까 May 16, 2023 pm 03:16 PM

사전 테스트 액세스 도메인 이름: www.test.com/api/upload1.location 및 Proxy_pass 모두 /를 포함하며, 위치가 없는 실제 주소는 디렉토리 location/api/{proxy_passhttp://127.0.0.1:8080/;}와 일치합니다. 액세스 주소: www.test.com/api/upload-->http://127.0.0.1:8080/upload2.location에는 /가 포함되어 있지 않으며, Proxy_pass에는 /가 포함되어 있으며, 실제 주소에는 /location/api{proxy_passhttp가 포함됩니다: /

See all articles