Del I
Revideret 9. december 10 01:00 EST
Kiggede på din DDL. Okay. Vi er nødt til at tage et skridt tilbage og organisere din database først. Det vil løse halvdelen af dine problemer (din SQL vil være ligetil; og hurtig; færre indekser; ingen midlertidige tabeller påkrævet). I et stykke tid tænkte jeg, aha, du har dine kolonner, det skal være stabilt, men der er ingen chance. Top ned fra bunden, ok. Tag et kig på dette Entity Relation Diagram (det nytter ikke at arbejde på datamodellen, som er Entities, Relations og Attributes , indtil vi får ER'erne rigtige), og kontroller, at det er korrekt.
-
Måden at gøre det på er at besvare følgende spørgsmål (korte svar er fint). Disse spørgsmål præciserer enheder og forretningsregler . Hvordan du forstår databaser generelt, og dine data i særdeleshed, er afgørende. Du er nået langt på egen hånd, så vi kan tage det derfra.
-
Jeg tror, ▶dette indlæg◀ stærk> kan være nyttigt for dig, for at forstå de formelle stadier, der bør følges; som vi kortslutter her.
-
Vigtigst, helt og fuldstændigt, glem alt om funktionen og eventuelle kodningskrav. Data skal modelleres uafhængigt af applikationen, simpelthen som data. Funktionsmodellering er en anden videnskab. Få først en rigtig; så få den anden ret; og de to sammen spiller smukke melodier. Prøv at sætte dem sammen; udfører begge opgaver på samme tid, og de vil ikke engang lave et forstadsgarageband.
For kortheds skyld, og for enhver, der læser dette, bruger jeg en lukket og åben sektion; når et åbent emne (diskussion) er lukket, vil jeg gøre det kortfattet og flytte det til sektionen lukket. Fasthold nummereringen, for nogle gange kommer tingene tilbage for at hjemsøge os. Du ønsker måske at gøre det samme, eller endda slette diskussionen på din side.
Linkene til de smukke billeder er til sidst.
Undskyld:redigeringen virker ikke; undernummerering er inkonsekvent
Lukkede numre
- users.bb_locations_csv er en mange-til-mange-relation mellem brugere og lokationer:
- Hvert af disse elementer skal være en indgang i en diskret kolonne, i en diskret række
- En bruger kan have mange lokationer og 1 placering kan have mange brugere er mange-til-mange
- Læs ▶dette indlæg◀ for en diskussion af, hvordan det behandles, og hvilket stadium det behandles
- På dette logiske stadie er det bare en n::n relation, som jeg har tegnet, du kan glemme det for nu, det vil blive leveret, ganske enkelt, når vi kommer til det fysiske stadie.
- Tro mig, jeg leverer kode, der ikke er mere kompleks end
...WHERE IN ()
til dit erklærede formål. - Ved nærmere eftertanke, hvis jeg brækker dine fingre, vil du skrive endnu langsommere, så jeg må hellere lade være
- Ok, din app er browserbaseret, og siden er dynamisk (mit råd var statiske sider, der skal korrigeres); gå videre med afkrydsningsfelter.
.
- users.bb_categories_csv er mange-til-mange-relation mellem brugere og kategorier
- Ditto.
.
- Ditto.
-
Bekræftet:en bulletin (bbs) eksisterer ikke uden en bruger; en bruger udsender en bulletin, og det starter hele cyklussen; inviterer derefter til svar og vurderinger.
3.1 Bekræftet:Der er faktisk kun én opslagstavle, og den eksisterer ikke som en ting i databasen.
3.2 Bekræftet:at organisationen aldrig vil have mere end én opslagstavle, og klassifikationerne og kategoriseringerne er alle tilstrækkeligt håndteret af kategoritabellen/funktionen
-
Slettet.
-
Bekræftet:Forskellen mellem bulletiner og svar er, at svar er afhængige af, at en bulletin eksisterer, de har ikke en titel, og de er ikke kategoriseret efter placering eller kategori, fordi de er afhængige af, at bulletinen selv eksisterer.
-
Slettet.
-
Bemærkninger noteret. Løst.
7.1. For hver enkelt bulletin indsendt af en anden bruger kan hver bruger sende mere end ét svar.
7.2. For hver enkelt bulletin indsendt af en bruger kan denne bruger sende et eller mere end ét svar.
7.3. Slettet.
7.4. Slettet.
.
8. Bekræftet:hver bruger kan højst sende én vurdering til en bulletin (som kan tilbagekaldes/ændres)
.
9. Bekræftet:hver bruger kan højst skrive en vurdering til et svar (ditto)
10.1. Givet:brugernavn kommer fra organisationen og er det unikke navn, der identificerer medarbejdere. For eksempel er e-mails eksample.com@aq>ldat. - autentificering foretages med ldap og dette er påkrævet for at kunne forbinde og hente andre oplysninger om medarbejderne
- Bekræftet:Brugernavn er en fremragende identifikator
10.2. Bekræftet:Fornavn, Efternavn ... Fødselssted osv. forbliver som (de traditionelle) kolonner for at sikre People
er ikke duplikeret.
.
11. Givet:I øjeblikket kan vi identificere vores kontorer ved tilfældige navne, som er almindeligt kendte i organisationen, da vi kun har omkring 3 hovedkontorer og mange feltkontorer. Så eksempler ville være Washington DC eller virginia field office. I alt tror jeg, vi vil forsøge at holde det samlede antal under 20. Jeg vil også registrere den nøjagtige adresse på hver lokation, fordi det kunne bruges til entydigt at identificere kontorer for brugerne.
- Forudsat:
StateCode+Town
som PK;IsMainOffice
som boolesk.
.
12. Bekræftet:Description
og Name
for Category
er påkrævet.
.
13. Givet:Brugere vil ikke være i stand til at skrive til nogle kategorier. Kun brugere med tilstrækkeligt høje rettigheder vil have ret til at skrive til bestemte kategorier.
- Forudsat:
Permission
iUser, Location, Category
er en metode til at vurdere sådanne rettigheder.
.
14. Bekræftet:Location.Administrator
er UserId
af admin for Location
.
.
15. Givet:Der vil kun nogensinde være behov for et like eller et antipati. Jeg tror ikke, der behøver at være en neutral holdning, fordi det er det samme som bare ikke at stemme? Synes om synes mere relevant for bulletinsvar, der poster for at være ærlig. Dvs. 'Jeg kan se dit svar, og i stedet for at skrive mit eget, vil jeg bare være enig med dig - den eksisterende opslagstavle er noget af et socialt aspekt i organisationen, og jeg tror, at man kan lide og ikke lide/enig og uenig skaber et niveau af kontrovers, der tilskynder til deltagelse . Men at kunne lide eller ikke lide en bulletin er måske ikke altid helt passende.
15.1 Forudsat:Like
som boolesk i BulletinRating
og ResponseRating
. Dette vil kræve fortolkning ved hver adgang.
15.2. Når det ikke længere er en boolean, kan den ændres til en RatingCode
, og implementeret som en opslagstabel. Navnene bestemmes derefter af Joins, og fortolkning er elimineret. Jeg tegnede dette i den første datamodel, så du kunne se, hvad jeg mente15.3. Fjernet i den anden datamodel.
.
16. Bekræftet:hver bruger har et hjem Location
(bortset fra listen over Locations
som de er interesserede i).
.
17. Bekræftet:Permission
i henhold til (13).
.
18. Bekræftet:Yderligere tilladelser kan være påkrævet i henhold til datamodel.
18.1. Hvis du gør dette nu, behøver du ikke bekymre dig om, hvornår organisationen beslutter at forhindre en bestemt Person
fra at sende Responses
eller Bulletins
, eller Bedømme dem; og vil have den funktion implementeret i går.
18.2. Selvom du ikke implementerer det, skal du efterlade mellemrum mellem de værdier, du implementerer.
.
19 Bekræftet:en Bulletin
handler om en Location
.
19.1. Bekræftet:Der er ingen Bulletins
uden en Location
19.2. Bekræftet:Der er ingen Bulletins
uden en Location
.
19.3 Bekræftet:Der er ingen Bulletins
uden en User
(deklarativ). Men indtil videre har vi ingen mulighed for at begrænse den User
; derfor enhver User
kan indsætte en Bulletin
for enhver Location
(du kan begrænse det i kode, f.eks. til Locations
hver User Is Interested In
.
19.4 Bekræftet:Der er ingen BulletinRatings
uden en Bulletin
og en bedømmelse User
.
19.5 Bekræftet:Der er ingen Responses
uden en Bulletin
.
19.4 Bekræftet:Der er ingen ResponseRatings
uden et Responses
og en bedømmelse User
.
19.7. Men der kan være Users
, Locations, and
Kategorier`, uafhængigt.
.
20. Hvis du ikke har noget imod det, vil jeg give navnekonventioner osv. De burde være selvforklarende, og værdien vises først, når du begynder at kode SQL. Spørg venligst, hvis noget ikke er. Til at begynde med er alle navne ental. Blandet store og små bogstaver er lettere at læse (det er meningen, at du skal bruge store bogstaver til SQL-sprog).
20.1. Min erfaring er, at tabelnavn i modsætning til tabelnavn virkelig er tekniske former, og brugere kan ikke lide dem; Konsekvent blandet sag er godt for alle. Det er en af de ting, der er umulige at ændre, så vælg med omhu.
.
21. For dit behov for at gruppere borde sammen, hvilket er godt, skal du huske på, at det er et fysisk problem. På logisk datamodelniveau har tabellerne normale navne uden fysiske problemer. Forestil dig, at de fysiske tabeller er præfikset med noget i stil med (og brug venligst store bogstaver til dette):
- REF_
til reference (såsom bruger) og opslagstabeller
- BUL_
til Bulletin-systemet
.
Jeg kan ikke navngive tabeller med store bogstaver? Jeg er ikke sikker på hvorfor. Jeg ved ikke, hvorfor jeg ikke kan have store tabelnavne. Er det at gøre med at bruge MyIsam-databasetabeller?
.
22. rank
(alle) kan udledes direkte fra databasen (husk, du skal ikke bekymre dig om koden under datamodellering). Hvis du gemmer det, er det en normaliseringsfejl; en duplikeret kolonne; som skal holdes ajour; som kan komme ud af synkronisering med den afledte værdi; som kaldes en Update Anomaly. Femte normalform eliminerer opdateringsanomalier. Det er mit minimumsniveau af normalisering, så det er det, du får fra mig.
22.1. Jeg blander mig overhovedet ikke i sorteringsrækkefølgen eller popularitetsspørgsmålet; faktisk, ved lyden af det, har du ikke lukket denne funktionalitet. Jeg tager kun overflødige data, rangerings-kolonnen , ud, som en del af normaliseringsprocessen.
22.2. Her er en ▶Quick Tutorial◀
på RANK() operatoren (som det er almindeligt kendt). Det er ikke ANSI SQL; det er en Oracle- og MS-udvidelse. Det er dog ikke påkrævet, hvis du forstår Subqueries, hvorfor Sybase ikke har det. Jeg tvivler på, at MySQL har det, så du skal have hovedet omkring det. Forståelse af skalære underforespørgsler er en forudsætning. Sybase-syntaks, så smæk dine semikoloner ind osv. Stil gerne specifikke spørgsmål.
.
Jeg har aldrig set den fremgangsmåde med at skrive Rank =(SELECT.... Er det det samme som (SELECT ...) som Rank?
.
22.3. At skulle forstå hvorfor er ikke noget problem overhovedet. Kun børn følger blindt simple regler, og du er bestemt ikke en af dem.
.
23. Bekræftet:users.total_bulletins
er overflødig; det kan udledes. Fjernet.
.
24. Alle dine PK'er er id'er. Er du ikke blevet træt af at fare vild i koden endnu? Glem alt om at sætte Id
fast iot PK'er på alt, der bevæger sig, lad os finde ud af, hvordan dine brugere Identificere deres enheder; hvilke enheder er virkelig uafhængige, og de andre, der afhænger af uafhængige enheder.
24.1. Brug aldrig Id
eller enhver sådan form. Hvis det er en PK, skal du bruge den fulde formular.
24.2. Kald location_id, location_id, uanset hvor det er, inklusive PK-tabellen. Undtagelsen er, når du skal vise rollen. Dette vil blive tydeligt i datamodellen.
.
25. Du har ingen deklarativ referenceintegritet, ingen defineret Fremmednøgler. Det er dårlige nyheder af mange forskellige årsager. Når disse spørgsmål er afklaret, bedes du tilføje dem. DRI betyder, at så meget som muligt, hvis ikke alle, integritet er erklæret i SQL. ISO/IEC/ANSI SQL-standarden tillader dette, men freeware-enden af markedet leverer ikke standarden og er langsomt ved at indhente det. Det betyder, at serveren ikke tillader, at en række i FK-tabellen tilføjes, medmindre PK'en findes i den overordnede tabel. MySQL leverede for nylig DRI til fremmednøgler. For FK'er, se ▶ denne artikel◀
.
25.1. For CHECK-begrænsninger og REGLER skal du implementere dem i kode.
mine fremmednøgler er som, users-id(fk) =users.id(pk) Jeg er ikke sikker på, hvordan jeg tilføjer dem andet end det, jeg har gjort, men vil helt sikkert gøre det, når jeg ved, hvordan.
Femogtyve. Kommentarer noteret. Jeg er ikke en MySQL-specialist. Ja, det er de problemer, du selv skal finde ud af. Generelt set fra min gennemlæsning er MySQL benløs; til noget SQL-agtigt har du brug for InnoDB.
.
27. Givet:Jeg har genovervejet sorteringskravene til bulletin. Brugere kunne sortere kronologisk - nemt, giver mening. Brugere kunne sortere bulletiner efter datoen for det seneste svar på bulletinen. Så kan vi glemme rang, og det burde være virkelig nemt at sortere bulletiner kronologisk efter tidspunktet for deres sidste svar? Hvad er dine tanker.
Åbne numre
(Nul)
Datamodel
Ok, forudsat at du ikke har problemer med ERD og implementerer alle lukkede problemer, har jeg modelleret dataene og udarbejdet en femte datamodel 09. december 10 til dit gennemsyn. Jeg har bestemt brug for meget mere feedback, spørgsmål osv. herom. Jeg har svært ved at acceptere, at det er gjort. Det er nok bedst at begynde at skrive rigtig kode til dine problemområder.
Links
▶Link til IDEF1X-notation◀ Du skal virkelig læse og forstå dette, før du læser Datamodellen.
▶Link til Fifth Bulletin Data Model◀ Entity Relation Diagram er på den første side, efterfulgt af datamodellen .
-
Nøglerne er stort set lige IDEF1X (bortset fra UserId, som jeg angav som et modspil); hvilket betyder pung Relationelle nøgler. Uforbedret og ikke optimeret til fysiske overvejelser. Før du bulker på dem, skal du først lægge mærke til dem, registrere dem og evaluere dem. Selvfølgelig kan vi tilføje
Id
iot-nøgler, men før vi gør det, så lad os sikre os, at vi forstår, hvad vi kommer til at miste. -
Læg mærke til identifikatorerne (optrukne linjer) i henhold til notationsdokumentet. Rygsøjlen, systemets ryghvirvler er
Location ... Bulletin ... Response
. -
Bemærk, at Keys faktisk implementerer mange forretningsregler.
-
Læg mærke til det naturlige hierarki, som jeg har gengivet. Se om der er nogen mening i det for dig.
-
Verbsætningerne er virkelig vigtige; se om de betyder noget.
Kommentarer til First Data Model og svar
Et spørgsmål, jeg har, er, at den primære nøgle for placeringen vil blive brugt til at danne den underordnede primære nøgle? (de er forbundet med en ubrudt linje) Jeg forstår ikke rigtig det koncept
- Hvad er en god identifikator for Bulletin? , hvad bruger dine brugere naturligt til at identificere en bulletin ...
- "har du set bulletinen fra Virginia FO i går?",
- "Sally fra Washington skriver helt sikkert gode bulletiner", osv.
eller hvorfor dette forhold ikke eksisterer mellem brugeren og bulletinen?
-
I henhold til hensigten angivet yderligere ovenfor, da jeg nu har vist Rating som en tabel, og hvad gengivelsen ville være, fjerner jeg den én gang
-
Jeg synes, at Tilladelse skal være en enhed.
-
Bulletin
PK er nu(StateCode, Town, UserId, SequenceNo)
. For at være tydelig,SequenceNo
er inden forStateCode, Town, UserId
:det bliver 5 for Sallys 5. bulletin om MO/Billngs FO. -
Bemærk, at brugerindstillinger
BulletinsPerPage
,etc, er 1::1 medUser
, så de er iUser
; underordnet tabel ville være forkert. -
Typografiske fejl rettet.
Kommentarer til anden datamodel og svar
- PK'erne for begge
Bulletin
ogResponses
er blevet ændret til at afspejle (7).BulletinNo
ogResponseNo
er blevet erstattet medBulletinDate
ogResponseDate
(som plejede at væreCreatedDate
), for at tillade flere svar pr.User
ifølgeBulletin
.
Kommentarer vedrørende tredje datamodel og svar
Stol på, at du havde en god pause.
-
For mindst 30 år siden (det er jeg bekendt med) havde giganterne i branchen denne debat. Navne er altid ental. Tabeller er navneord. Verbsætninger er verber. Dette er ikke begrænset til db navngivningskonventioner, det gælder for dokumenter, afhandlinger, afhandlinger osv. Du kan have 5 konklusioner i slutningen af dokumentet, men afsnittet eller kapitlets titel i både indholdsfortegnelsen og toppen af siden er "Konklusion".
Efter at have kæmpet mod dem hele vejen gennem Uni, så snart jeg startede mit første betalte programmeringsjob, og så vigtigheden af reglerne i den virkelige verden, i modsætning til de teoretiske argumenter, vi havde på college, opgav jeg det som spild af tid. Al den tid og energi, jeg spildte, blev frigivet til at udføre produktivt arbejde. Siden da stiller jeg ikke spørgsmålstegn ved giganterne; Jeg accepterer bare. At deres sind er større end mit. Det er som at acceptere standarder eller opføre sig inden for loven eller Gud. Jeg har ingen rigtig, rigtig gode grunde til at gøre noget ulovligt.
Under alle omstændigheder kan den lette sprogbrug (diskussion, SQL, dokumentation), der understøttes af sådanne regler, ikke forklares tilstrækkeligt; efterhånden som du skriver mere og mere SQL-kode, vil det blive tydeligt.
Du er altid fri til at bruge, hvad du vil. Jeg leverer kun ental.
-
Fint med mig.
Men du skal huske på, at disse to elementer i den identificerede rækkefølge (ala ikke-PK Unique Index eller Alternativ Key) er universelt nødvendige for at etablere Uniqueness for en Person. Fjernelse af dem vil resultere i to ting. For det første vil du ikke længere være i stand til at identificere unikhed på tværs af
Users
(og dermed kan du have duplikerede rækker). For det andet bliver AK'en ikke-unik, en Inversion Entry. -
Pointen er (i modsætning til et af indlæggene), enhver kolonne, der er 1::1 med
User
PK, bør ligge iUser
. Alle præferenceindstillinger. Siden vi har ryddet op iInterestedLocations
ogInterestedCategories
, jeg kender kun tilBulletinsPerPage
resterende; men jeg er sikker på, at der er andre.IsPreference2
er en f.eks. af en boolesk;NumPreference3
er en f.eks. af et heltal. Osv. Du kan fortælle mig, hvad de rigtige præferencer er.(Lad os prøve det i flertal:... enhver kolonne, der er 1::1 med
Users
PK, bør ligge iUsers
. Det gør det bare ikke for mig, jeg bliver hængt op i det ødelagte engelsk, og jeg er lidt dyrebar med mit modersmål.)Datamodel opdateret.
-
Fremragende. Lad mig vide, når du er tryg ved det, og jeg vil give dig den fysiske model.
Hvad med verbsætningerne?
Kommentarer om 06. december 10 20:38 EST (Små opdateringer)
.
28. Hvor der kun er én forekomst af PK som FK, er FK kolonnenavnet selvfølgelig det samme som PK kolonnenavn. Men når der er mere end én occ af FK'en (tag et kig på ResponseRating
), er der tre UserIds
), er vi nødt til at differentiere dem. I IDEF1X terminologi kaldes dette roller. User
s rolle der har udstedt Bulletin
er Issuer
, og så videre. Det er klart, at det er bedre at bruge dette navn og holde det konsistent i hele hierarkiet (ikke UserId
i Bulletin
og så når vi kommer til Response
, hvor der er to, og der kræves en differentiering, skal du ændre den til IssuerId
. Jeg tænkte, at du måske havde et problem med det; i de tidlige stadier er brugen Issuer.UserId
så det er helt klart, at det er UserId
som en FK, og rollen er Issuer
; når vi kommer til den fysiske model, bliver den forenklet til IssuerId
.
Ligeledes har vi mange DateTime-kolonner (dato for kort hvis du vil; ellers Dtm), der skal differentieres.
.
29. Gav IDEF1X-notationsdokumentet ikke mening?
- PK for hver tabel er over linjen i den angivne rækkefølge.
- Husk, at vi alligevel bærer PK'erne fra de overordnede tabeller, og hvis der er mening, skal du bruge disse FK'er til at danne den underordnede PK.
-
Til
Bulletin
:- Placeringen FK
(StateCode, Town)
som den er udstedt for UserId
af Udsteder- og DateTime det blev udstedt, for at gøre det unikt.
- derfor (StateCode, Town, IssuerId, BulletinDate)`
- Placeringen FK
-
For at slette alle
ResponseRatings
for denneBulletin
, brugWHERE =
på de fireBulletin
kolonner.
.
30. Fordi (State, Town)
er PK for Location
, bærer overalt. Og det er en del af Bulletin
PK, så alle afhængige tabeller bærer disse kolonner, fordi de bærer Bulletin
PK.
Vi havde tidligere identificeret den (State, Town)
er PK, Jeg vil lade det være som det er Se (38) for ændring.
.
33. Værd at diskutere. Ja, hvis du vil vise det, når du (f.eks.) viser Responses
, og brugerne forstår UserName
. Nej, hvis det er 30 bytes, og der også er et unikt 4 byte UserId
. Ideen er at træffe disse valg bevidst, bevidst om, hvad du giver op, når du til sidst beslutter dig for, at en 6-søjle 30-byte nøgle er for besværlig til at migrere til børnene.
- Jeg sagde i starten, at jeg ville bruge
UserId
som et typiskId
Pk, fordi den føres/migreres til flere underordnede borde. - Vi kan lade, hvordan det er oprettet, til senere. Men det er en ren surrogat-PK.
.
34. Intet problem. Category
har det allerede. Jeg ændrer Order
til ListOrder
.
.
35. Jo da. Ud fra hvad jeg har læst og hørt, er jeg ret glad for den. Men jeg vil gerne have mere frem og tilbage for at opnå noget selvtillid, før du skriver kode. Alternativt kan du se det som en lærerig oplevelse og acceptere, at modellen og koden kan ændre sig senere. Vil du have mig til at producere den fysiske nu? Hvis du giver mig alle rettelser, udgiver jeg den næste version. Jeg forventer præferencer i User
. Kør også hurtigt gennem funktionerne og kontroller, at du har alle de kolonner, du har brug for.
Se på nogle af de andre svar med henblik på læring og interesse.
.
36. slutter sig til. Du deltager bare på four tre kolonner i modsætning til én. SQL er besværligt med joins, og den nye syntaks, som skulle gøre det nemmere, er faktisk mere besværligt. Mine kodere skriver aldrig joins:vi sparer tid og tastefejl. Jeg har en proc, der givet to eller flere tabeller, vil generere koden med alle kolonner og joins. Jeg kender ikke nok til MySQL til at konvertere det for dig.
Datamodel opdateret.
.
Kommentarer ad 8. december 10 20:49, fjerde datamodel og svar
.
Tjek det forrige afsnit umiddelbart ovenfor, der er små opdateringer.
IDEF1X:Din hastighed er fin.
Bemærk barnet altid "arver" den overordnede PK, som en FK (enten fast eller brudt linje), ellers er der ingen relation mellem dem. Ved at bruge disse kolonner, der alligevel findes i barnet, til at danne underordnet PK, bærer vi betydningen (og det er forskellen mellem solid og ødelagt). Og dermed behøver vi ikke lede efter en selvstændig Identifier for barnet. Den relationelle kraft i denne metode vil blive tydelig senere, når du koder.
Det afsnit, vi har at gøre med, handler om Identifiers :naturlig vs unaturlig; meningsfuld vs meningsløs. Senere vil du se, hvordan vi kan bruge motorens Relationelle kapacitet, når den underordnede PK er dannet fra den overordnede PK. (Er dit efternavn ikke det samme som din fars?)
Det er også vigtigt at forstå relationelle databaser og deres muligheder. Det går tabt, når vi nærmer os databasen (f.eks.) fra et OO-perspektiv og behandler den som et sted for at gøre vores klasser "vedvarende". Derfor vil vi forsøge at lære og bruge Relationelle termer. Det bliver svært, når man tager til Frankrig og forventer, at de taler amerikansk, og bruger samme valuta; lær at tale 10 ord fransk, og de tager imod dig med åbne arme, og du får en helt anderledes oplevelse med de lokale.
Under alle omstændigheder, gå videre med at implementere modellen. Bare indse, at vi sandsynligvis vil lave en ændring på et tidspunkt. Gem alle dine DDL. Gem alle dine testdata som insert-sætninger eller som en tabelbackup eller karakterformateksport (ingen anelse om, hvad MySQL kan/ikke kan gøre i dette område).
37.1. Håndteres, n::n Relation til Office
&Category
. Det vil du først "se", når vi kommer til den fysiske model.
37,2. Færdig.
37.3 Udført.
.
38. Fremragende. Også kortere. Bemærk, at de aldrig vil kunne have to Offices
i samme postnummer. NUMERISK(5,0) er godt, men jeg troede, at USA bevægede sig mod 7 cifre. Det gør ikke noget, du kan finde ud af det; det er en fremragende PK til Office
. Nu denne kolonne, som var en del af Address
, sandsynligvis ZipCode
, er blevet ophøjet til et højere formål uden dobbeltarbejde; da vi bærer det i 5 underordnede tabeller, og vi ønsker, at PK-navnet skal være klart, vil vi ifølge tidligere forklarede konventioner kalde det OfficeCode
; OfficeZipCode
kan være dumt.
Vi har brug for et unikt indeks på Name
for at sikre, at de ikke tilføjer to Offices
med samme navn. Bemærk, til forklaringsformål er dette faktisk den logiske nøgle til Office
, erstatter (StateCode, Town)
, og det forbliver sådan.
Jeg tror stadig, at du muligvis har brug for StateCode
og Town
som en hurtig reference (bortset fra at sidde et sted i Address
). )
Datamodel opdateret, femte nu tilgængelig til gennemgang. Du har ikke angivet din præference for ...Date
vs ...Dtm
. Jeg går med sidstnævnte, da det er mere specifikt, og identificerer også tidskomponenten. Let at ændre.
Dette svar har nået den maksimale længde. Fortsat i "Del II"