데이터 베이스 MySQL 튜토리얼 主键和外键的作用

主键和外键的作用

Jun 07, 2016 pm 03:22 PM
기본 키 효과 외래 키 다수의

主键和外键是把多个表组织为一个有效的关系数据库的粘合剂。主键和外键的设计对物理数据库的性能和可用性都有着决定性的影响。 必须将数据库模式从理论上的逻辑设计转换为实际的物理设计。而主键和外键的结构是这个设计过程的症结所在。一旦将所设计的数据库

主键和外键是把多个表组织为一个有效的关系数据库的粘合剂。主键和外键的设计对物理数据库的性能和可用性都有着决定性的影响。

必须将数据库模式从理论上的逻辑设计转换为实际的物理设计。而主键和外键的结构是这个设计过程的症结所在。一旦将所设计的数据库用于了生产环境,就很难对这些键进行修改,所以在开发阶段就设计好主键和外键就是非常必要和值得的。

主键:

关系数据库依赖于主键---它是数据库物理模式的基石。主键在物理层面上只有两个用途:

1. 惟一地标识一行。

2. 作为一个可以被外键有效引用的对象。

基于以上这两个用途,下面给出了我在设计物理层面的主键时所遵循的一些原则:

1. 主键应当是对用户没有意义的。如果用户看到了一个表示多对多关系的连接表中的数据,并抱怨它没有什么用处,那就证明它的主键设计地很好。

2. 主键应该是单列的,以便提高连接和筛选操作的效率。

注:使用复合键的人通常有两个理由为自己开脱,而这两个理由都是错误的。其一是主键应当具有实际意义,然而,让主键具有意义只不过是给人为地破坏数据库提供了方便。其二是利用这种方法可以在描述多对多关系的连接表中使用两个外部键来作为主键,我也反对这种做法,理由是:复合主键常常导致不良的外键,即当连接表成为另一个从表的主表,而依据上面的第二种方法成为这个表主键的一部分,然,这个表又有可能再成为其它从表的主表,其主键又有可能成了其它从表主键的一部分,如此传递下去,越靠后的从表,其主键将会包含越多的列了。

3. 永远也不要更新主键。实际上,因为主键除了惟一地标识一行之外,再没有其他的用途了,所以也就没有理由去对它更新。如果主键需要更新,则说明主键应对用户无意义的原则被违反了。

注:这项原则对于那些经常需要在数据转换或多数据库合并时进行数据整理的数据并不适用。

4. 主键不应包含动态变化的数据,如时间戳、创建时间列、修改时间列等。

5. 主键应当有计算机自动生成。如果由人来对主键的创建进行干预,就会使它带有除了惟一标识一行以外的意义。一旦越过这个界限,就可能产生认为修改主键的动机,这样,这种系统用来链接记录行、管理记录行的关键手段就会落入不了解数据库设计的人的手中。

数据库外键的使用

外键的作用我认为主要有两个:一个是让数据库自己通过外键来保证数据的完整性和一致性,一个就是能够增加ER图的可读性。我觉得第二点的重要性甚至比第一点还高。

有些人认为外键的建立会给开发时操作数据库带来很大的麻烦,因为数据库有时候会由于没有通过外键的检测而使得开发人员删除,插入操作失败,他们觉得这样很麻烦,其实这正式外键在强制你保证数据的完整性和一致性,这是好事儿。

应该说如果系统比较小,外键的作用可能不会很明显,如果你的系统后台有几百个表的话,没有外键的数据库设计是我无法想象的,有一个基础数据的表:商品,其他表都保存商品ID ,查询时需要连表来查询商品的名称,单据1的商品表中有商品ID字段,单据2的商品表中也有商品ID字段,如果不拉出外键的话,当单据1,2都使用商品ID为3的商品后,删除此商品后,再查看单据1,2的时候就会查不到商品的名称

当表很少的时候,有人认为可以在程序实现的时候来通过写脚本来保证数据的完整性和一致性,也就是在删除商品的操作的时候去检测单据1,2中是否已经使用了商品ID为3的商品,但是当你写完脚本之后系统有增加了一个单据3
他也保存商品ID找个字段,如果不拉出外键,你还是会出现查不到商品名称的情况,你总不能每增加一个使用商品ID的字段的单据时就回去修改你检测商品是否被使用的脚本吧

第二点就是增加ER图的可读性。这也同样是在后台数据库表非常多的时候能够体现出来的,外键能够明确的两个表之间的关系,例如一个单据的主表和单据的品的子表,如果两个表没有拉出外键表明关系,且两个表的位置在ER图中很远,对于一个对这个系统不是非常了解的人来说,让他去理出两个表之间的关系是很麻烦的,如果你拉出外键就算两个表离的很远,他也能随着外键找出他们之间的关系来,ER图的可读性对于一个刚刚接触大型系统的新手来说是极为重要的。

当然,外键的个数也不是没有个尺度,因为外键拉的过多会使ER图极为混乱(到处都是线) ,所以应该掌握合适的尺度才行,必要的外键必须要拉出来。如果实在不想因为外键过多而造成ER图的混乱,可以对基础数据的删除用假删除的办法,以避免在没有外键约束和检查的情况下造成数据的不一致性。

uniqueidentifier数据类型

uniqueidentifier数据类型可存储16字节的二进制值,其作用与全局唯一标记符(GUID)一样。GUID是唯一的二进制数:世界上的任何两台计算机都不会生成重复的GUID值。GUID主要用于在用于多个节点,多台计算机的网络中,分配必须具有唯一性的标识符。 在SQL中 ROWGUIDCOL表示新列是行的全局唯一标识列。对于每个表只能指派一个uniqueidentifier 列作为ROWGUIDCO列。ROWGUIDCOL属性只能指派给uniqueidentifier列
一 什么是uniqueidentifier?
Uniqqueidentifier 是全局唯一的标识

p d [3~)F F C E0二 UniqueIdentifier 数据类型的列如何赋值?
1 使用 NewID()函数 来实现
2 直接将字符串的常量转化成这样的格式 xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
举例:6F9619FF-8B86-D011-B42D-00C04FC964FF 为有效的UniqueIdentifier数据
3 直接赋于32位的十六位数据
举例 0xffffffff00000000ffffffff00000000
三 UniqueIdentifier 数据类型 数据实际是怎么在数据库中保存的?
UniqueIdentifier 数据类型存储实际的数据是16个字节的二进制值,
UniQueIdentifier 可以转化成实际的字符串型和二进制数据类型

四 NewID()函数是如何生成唯一的UniqueIdentifier 值的呢?
NewID()函数是从他们的网卡上的标识数字和CPU时钟的唯一的数字生成新的UniqueIdentifier数据 ,这个数据和GUID是一样的每台计算机能生成全球唯一的值
这样在多台计算机和多网络之间生成具有唯一性的标识符

五 使用 Uniqueidentifier数据类型的主要的优点
Uniqueidentifier 数据类型主要的优点是在使用newid函数生成值的时候是可以保证值的全球唯一性
可以唯一的标识单行的记录 对于多库(尤其是多机器,多网段的数据库的复制)来将比IDEntity来的更有效
其次在使用Identity的情况下,我们对自动生成的值是不能修改的,而Uniqueidentifier数据类型是可以随时修改的

六 使用Uniqueidentifier的数据类型的缺点
1 对于生成的Uniqueidentifier 类型的值来讲 ,是无序
在正常显示相关的数据信息的时候,返回的信息是无序的ITPUB个人空间 p e%A _0`2I l(G!v t0]
对于 Identity 为标识的数据显示的时候,默认的情况下是根据添加记录的顺序来显示的。这样,对于uniqueidentifier为主键的信息集 ,还是需要一个默认标识排序的字段。

2 对于Uniqueidentifier 字段来将数据的实际的信息为16个字节,相对来将比Identity来讲 大的多,相对来将 存储空间和查询的效率会降低很多的。

七 在系统数据库的设计中我们如何对Uniqueidentifier,Identity ,和可标识的记录属性(有实际的含义的信息)作为主键 ,这三种方式 进行取舍

以属性为主键的系统设计情况
在系统设计的过程中
单条信息中包含可以表示唯一性的属性(一般不能太多3个以内)而且这样的属性是必填字段。在记录生存周期内一般是不进行改动的,表一般多于50个这样级别的系统
以属性为主键 ,这样的方式还是最佳的

举例: 关于学生的管理信息系统 以学生的学号为主键

以Uniqueidentifier 列为主键的情况
在需要多个数据库之间,多个网段之间需要进行数据库的复制时,我们就需要在每一个唯一的标识来区别每一个单条记录,在没有合适的属性来做主键的情况下可以用Uniqueidentifier列来生成主键

以 Identity为主键的情况
不需要数据库的复制,和系统比较小的情况下(50表以内)可以用 Identity列来生成主键,适合于快速开发

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

win11의 터치 키보드 기능 및 용도 win11의 터치 키보드 기능 및 용도 Jan 03, 2024 pm 04:40 PM

win11 설정을 탐색하면 터치 키보드 설정이 있는 것을 알 수 있지만 우리 화면은 터치 스크린을 지원하지 않습니다. 그렇다면 이 win11 터치 키보드의 용도는 무엇입니까? 실제로는 온스크린 키보드입니다. win11 터치 키보드의 기능: 1. win11 터치 키보드는 실제로 "화면 키보드"입니다. 2. 실제 키보드를 시뮬레이션하고 클릭하여 키보드를 사용할 수 있습니다. 3. 키보드가 없거나 키보드가 고장난 경우 키보드를 사용하여 입력할 수 있습니다. 4. Win11은 터치 키보드에 대한 다양한 맞춤형 옵션을 제공합니다. 5. 다양한 색상과 테마가 포함되어 있어 사용자가 원하는 스타일을 자유롭게 변경할 수 있습니다. 6. 키보드 레이아웃, 필기 및 기타 입력 방법을 수정하려면 왼쪽 상단에 있는 "기어"를 클릭하세요.

Linux DTS의 역할과 사용법 이해 Linux DTS의 역할과 사용법 이해 Mar 01, 2024 am 10:42 AM

LinuxDTS의 역할 및 사용법 이해 임베디드 Linux 시스템 개발에서 장치 트리(DeviceTree, 줄여서 DTS)는 시스템의 하드웨어 장치와 연결 관계 및 속성을 설명하는 데이터 구조입니다. 장치 트리를 사용하면 Linux 커널을 수정하지 않고도 다양한 하드웨어 플랫폼에서 유연하게 실행할 수 있습니다. 본 글에서는 LinuxDTS의 기능과 사용법을 소개하고, 독자의 이해를 돕기 위해 구체적인 코드 예제를 제공합니다. 1. 디바이스 트리 디바이스 트리의 역할

블루투스 어댑터는 어떤 용도로 사용되나요? 블루투스 어댑터는 어떤 용도로 사용되나요? Feb 19, 2024 pm 05:22 PM

블루투스 어댑터의 역할은 무엇인가요? 과학과 기술이 지속적으로 발전하면서 무선 통신 기술도 급속히 발전하고 대중화되었습니다. 그 중 블루투스(Bluetooth) 기술은 근거리 무선 통신 기술로 다양한 기기 간 데이터 전송 및 연결에 널리 활용되고 있다. 블루투스 어댑터는 블루투스 통신을 지원하는 중요한 장치로서 중요한 역할을 합니다. 블루투스 어댑터는 블루투스가 아닌 장치를 블루투스 통신을 지원하는 장치로 바꿔주는 장치입니다. 무선 신호를 블루투스 신호로 변환하여 장치 간 무선 연결 및 데이터 전송을 구현합니다. 블루투스 어댑터

PHP에서 정의 함수의 중요성과 역할 살펴보기 PHP에서 정의 함수의 중요성과 역할 살펴보기 Mar 19, 2024 pm 12:12 PM

PHP에서 정의 함수의 중요성과 역할 1. 정의 함수에 대한 기본 소개 PHP에서 정의 함수는 상수를 정의하는 데 사용되는 핵심 함수입니다. 상수는 프로그램 실행 중에 값을 변경하지 않습니다. 정의 함수를 사용하여 정의된 상수는 스크립트 전체에서 액세스할 수 있으며 전역적입니다. 2. 정의 함수의 구문 정의 함수의 기본 구문은 다음과 같습니다: Define("상수 이름","상수 값&qu

Gunicorn의 기본 및 기능에 대해 자세히 알아보세요. Gunicorn의 기본 및 기능에 대해 자세히 알아보세요. Jan 03, 2024 am 08:41 AM

Gunicorn의 기본 개념 및 기능 Gunicorn은 Python 웹 애플리케이션에서 WSGI 서버를 실행하기 위한 도구입니다. WSGI(Web Server Gateway Interface)는 Python 언어로 정의된 사양으로 웹 서버와 웹 애플리케이션 간의 통신 인터페이스를 정의하는 데 사용됩니다. Gunicorn을 사용하면 WSGI 사양을 구현하여 Python 웹 애플리케이션을 프로덕션 환경에 배포하고 실행할 수 있습니다. Gunicorn의 기능은 다음과 같습니다.

노흡의 기능 및 원리 분석 노흡의 기능 및 원리 분석 Mar 25, 2024 pm 03:24 PM

nohup의 역할과 원리 분석 nohup은 유닉스 및 유닉스 계열 운영체제에서 사용자가 현재 세션을 종료하거나 터미널 창을 닫아도 백그라운드에서 명령을 실행하는 데 일반적으로 사용되는 명령입니다. 아직도 계속 처형되고 있다. 이번 글에서는 nohup 명령의 기능과 원리를 자세히 분석해보겠습니다. 1. nohup의 역할: 백그라운드에서 명령 실행: nohup 명령을 통해 사용자가 터미널 세션을 종료해도 영향을 받지 않고 장기 실행 명령이 백그라운드에서 계속 실행되도록 할 수 있습니다. 이건 실행해야 해

Java의 휘발성 키워드의 사용 시나리오 및 기능에 대한 자세한 설명 Java의 휘발성 키워드의 사용 시나리오 및 기능에 대한 자세한 설명 Jan 30, 2024 am 10:01 AM

Java에서 휘발성 키워드의 역할과 응용 시나리오에 대한 자세한 설명 1. 휘발성 키워드의 역할 Java에서 휘발성 키워드는 여러 스레드 간에 표시되는 변수를 식별하는 데, 즉 가시성을 보장하는 데 사용됩니다. 특히, 변수가 휘발성으로 선언되면 변수에 대한 모든 수정 사항이 즉시 다른 스레드에 알려집니다. 2. 휘발성 키워드의 적용 시나리오 상태 플래그 휘발성 키워드는 다음과 같은 일부 상태 플래그 시나리오에 적합합니다.

PHP는 어떤 용도로 사용되나요? PHP의 역할과 기능 살펴보기 PHP는 어떤 용도로 사용되나요? PHP의 역할과 기능 살펴보기 Mar 24, 2024 am 11:39 AM

PHP는 웹 개발에 널리 사용되는 서버 측 스크립팅 언어입니다. 주요 기능은 HTML과 결합하면 풍부하고 다채로운 웹 페이지를 생성할 수 있습니다. PHP는 강력하며 다양한 데이터베이스 작업, 파일 작업, 양식 처리 및 기타 작업을 수행하여 웹 사이트에 강력한 상호 작용과 기능을 제공합니다. 다음 기사에서는 자세한 코드 예제를 통해 PHP의 역할과 기능을 자세히 살펴보겠습니다. 먼저, PHP의 일반적인 용도를 살펴보겠습니다: 동적 웹 페이지 생성: P

See all articles