AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Frage zu DB-Design

Ein Thema von hoika · begonnen am 14. Jan 2010 · letzter Beitrag vom 14. Jan 2010
Antwort Antwort
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#1

Frage zu DB-Design

  Alt 14. Jan 2010, 09:45
Datenbank: Firebird • Version: 1.5 • Zugriff über: egal
Hallo,

eine Frage zum Design.

Ich habe eine Tabelle mit Buchungen (~200.000 Einträge).
Auf die Tabelle wird oft per Select * zugegriffen,
es werden in der Tat alle Einträge benötigt.

Jetzt die Anforderung:
Zu einigen Buchungen sollen zusätzliche Informationen abgelegt werden
(etwa zu 1/2 % der Einträge).
Es handelt sich um 3 Felder

Datum
SmallInt
Integer

Es könnten aber auch noch 1/2 Felder dazukommen.

Lösung 1:
=========
Originaltabelle um diese Felder erweitern

Pro:
Direkter Zugriff auf diese Felder

Kontra:
Ein Haufen NULL-Felder, die mit übers Netz laufen.


Lösung2:
========
neue Tabelle mit Link auf die Buchungstabelle

Pro:
Original-Tabelle bleibt wie sie ist

Kontra:
Für den Zugriff muss per Join auf die neue Tabelle zugeriffen werden
Einen Left Join würde ich wegen der geringen Selectivität (1/2%) nicht machen

Da die Daten eh in interne Strukturen überführt werden (kein DBGrid)
wäre es eben eine zusätzliche Abfrage.


Was würdet ihr tun ?



Heiko
Heiko
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#2

Re: Frage zu DB-Design

  Alt 14. Jan 2010, 09:52
Zitat von hoika:
(etwa zu 1/2 % der Einträge).
Wenn Du jetzt noch sagst, was 1/2 % bedeuten soll, dann kann man antworten. So heisst es 0,5 %.
Zitat von hoika:
Es könnten aber auch noch 1/2 Felder dazukommen.
Allerdings gibt es kein 1/2 = 0,5 Felder. Und nun bin ich mit meinem Latein am Ende.
Gruß
Hansa
  Mit Zitat antworten Zitat
Matthias-k

Registriert seit: 7. Jul 2005
Ort: Freiberg
75 Beiträge
 
Delphi 7 Professional
 
#3

Re: Frage zu DB-Design

  Alt 14. Jan 2010, 10:11
ich an deiner stelle würde die extra tabelle bevorzugen...

der vorteil, das deine ausgangstabelle so bleibt, wie sie ist, ist nicht zu unterschätzen...

also ich vote für die dummy tabelle

mfg


Gebt Trollen keine Chance!!!
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#4

Re: Frage zu DB-Design

  Alt 14. Jan 2010, 10:15
Hallo,

2. Tabelle anlegen.
Für den Zugriff über ein Select ggfls. passende View machen.
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.351 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Frage zu DB-Design

  Alt 14. Jan 2010, 10:26
Hi,

ich würde mich an die Regeln (Normalformen) halten.
Ich glaube nicht, dass mit 3 Null-Feldern der Datenverkehr spürbar langsamer wird.

Wenn die Felder eindeutig zur Buchung gehören, dann macht eine Splittung keinen Sinn.

[EDIT]
Will man nicht alle Felder, erzeugt man eine View oder gibt beim Select die Feldliste an.
Im Fall gibt es für mich kein vernünftiges Argument, spezielle Regeln für das DB-Design einzuführen.
[/EDIT]

Frank
Frank Reim
  Mit Zitat antworten Zitat
franktron

Registriert seit: 11. Nov 2003
Ort: Oldenburg
1.446 Beiträge
 
Delphi 10.2 Tokyo Enterprise
 
#6

Re: Frage zu DB-Design

  Alt 14. Jan 2010, 10:27
Wenn du nur den SELECT machts also z.b. alle Daten in einer Grid Anzeigen tust dann würde ich die Felder anhängen,
wenn du jetzt aber nur ein ein Teil der Daten in der Grid anzeigen tust dann würde ich eine 2. Tabelle nehmen oder das SELECT anpassen oder eine VIEW nehmen.
Frank
Tux sein Lieblingsquellcode
While anzfische<TuxSatt do begin
Fisch:=TFisch.Create; Tux.EssenFisch(Fisch); Fisch.Free;inc(anzfische); end;
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#7

Re: Frage zu DB-Design

  Alt 14. Jan 2010, 10:46
Hallo,

ich werde das jetzt mit der 2. Tabelle machen.

Danke


Heiko
Heiko
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:48 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz