Kan een primaire sleutel ook een externe sleutel zijn?
Kan een primaire sleutel ook een externe sleutel zijn?

Video: Kan een primaire sleutel ook een externe sleutel zijn?

Video: Kan een primaire sleutel ook een externe sleutel zijn?
Video: Primary & Foreign Keys 2024, Mei
Anonim

Primaire sleutels moet altijd uniek zijn, buitenlandse sleutels moeten niet-unieke waarden toestaan als de tabel een een-op-veel-relatie is. Het is prima om een vreemde sleutel als de hoofdsleutel als de tabel is verbonden door een één-op-één-relatie, niet een één-op-veel-relatie.

Evenzo wordt gevraagd, kan een primaire sleutel ook een externe sleutel zijn in dezelfde tabel?

Een maken vreemde sleutel is bijna net zo eenvoudig als het maken van een hoofdsleutel , behalve dat SQL Server nog een aantal regels oplegt aan buitenlandse sleutels . Bijvoorbeeld de vreemde sleutel moet verwijzen naar een hoofdsleutel of unieke beperking, hoewel die verwijzing kan op de zijn dezelfde tafel of op een andere tafel.

En hoe verschillen primaire en externe sleutels? EEN primair key is een speciale sleutel die wordt gebruikt om records in een tabel uniek te identificeren, terwijl a buitenlands sleutel wordt gebruikt om de relatie tussen twee tabellen vast te stellen. Beide zijn identiek qua structuur, maar spelen verschillend rollen in het relationele databaseschema.

Hierin, kunt u een externe sleutel hebben zonder een primaire sleutel?

Ja. We kan Maak een Buitenlandse sleutel zonder hebben Hoofdsleutel in de oudertabel. De meesten van ons hebben de misvatting dat we kan maak geen a Buitenlandse sleutel zonder primaire sleutel in de oudertabel. Die unieke id kan zijn hoofdsleutel of uniek toets.

Kan een externe sleutel dupliceren?

In tegenstelling tot primair sleutels , buitenlandse sleutels kunnen bevatten duplicaat waarden. Het is ook OK dat ze NULL-waarden bevatten. Indexen worden niet automatisch gemaakt voor buitenlandse sleutels ; echter, als een DBA, u kan definieer ze. Een tabel mag er meer dan één bevatten vreemde sleutel.

Aanbevolen: