sql >> Database teknologi >  >> RDS >> Mysql

Hvordan binder man brugere til forskellige organisationer, universiteter, virksomheder med forskellige roller?

-- User USR exists.
--
user {USR}
  PK {USR}
-- Role ROL exists.
--
role_ {ROL}
   PK {ROL}

Xorg er en generisk betegnelse for et universitet, en organisation eller en fond. Discriminator TYP bruges til at skelne mellem disse tre.

-- Xorg XOG, of type TYP, named XNM was created
-- (is owned) by user USR.
--
xorg {XOG, TYP, USR, XNM, ...common_cols}
  PK {XOG}
  SK {XOG, TYP}

CHECK TYP in {'U', 'O', 'F'}

FK {USR} REFERENCES user {USR}
-- University (xorg) XOG, of xorg-type TYP = 'U', exists.
--
university {XOG, TYP, ...university_specific_cols}
        PK {XOG}

CHECK TYP = 'U'

FK {XOG, TYP} REFERENCES xorg {XOG, TYP}
-- Organization (xorg) XOG, of xorg-type TYP = 'O', exists.
--
organization {XOG, TYP, ...organization_specific_cols}
          PK {XOG}

CHECK TYP = 'O'

FK {XOG, TYP} REFERENCES xorg {XOG, TYP}
-- Foundation (xorg) XOG, of xorg-type TYP = 'F', exists.
--
organization {XOG, TYP, ...foundation_specific_cols}
          PK {XOG}

CHECK TYP = 'F'

FK {XOG, TYP} REFERENCES xorg {XOG, TYP}
-- User USR is member of xorg XOG, of xorg-type TYP,
-- in role ROL.
--
user_xorg {USR, XOG, TYP, ROL}
       PK {USR, XOG}

      FK1 {XOG, TYP} REFERENCES
     xorg {XOG, TYP}

      FK2 {USR} REFERENCES user  {USR}
      FK3 {ROL} REFERENCES role_ {ROL}

Bemærk:

All attributes (columns) NOT NULL

PK = Primary Key
AK = Alternate Key   (Unique)
SK = Proper Superkey (Unique)
FK = Foreign Key

Et ord om undertyper . Den korrekte måde at implementere begrænsninger for undertyper på ville være at bruge påstande (CREATE ASSERTION ), men den er stadig ikke tilgængelig i større DB'er. Jeg bruger FKs i stedet, og som alle andre erstatningsmetoder er det ikke perfekt. Folk skændes meget, på SO og SE-DBA, hvad der er bedre. Jeg opfordrer dig til også at tjekke andre metoder.




  1. FEJL:ORA-00917:manglende komma ved brug af Hibernate med en eksisterende sekvens i oracle

  2. Generer unikt ID

  3. Hvorfor udskriver PDO min adgangskode, når forbindelsen mislykkes?

  4. Postgresql Opret unikt indeks