MS Access - Feldgröße wichtig?

Mitglied: bvsn

bvsn (Level 1) - Jetzt verbinden

04.08.2006, aktualisiert 08.09.2006, 8166 Aufrufe, 2 Kommentare

Liebe Mitglieder,

ein Bekannter von mir behauptet, dass die Feldgröße der Felder in Access Datenbanken keinen Einfluss auf die Performance haben. Ich bin der Meinung, dass Access, wenn ich die Feldgröße für ein Textfeld auf 255 Zeichen stelle, auch soviel Speicher reservieren muss. Mein Bekannter sagt, Access speichert die Feldwerte dynamisch und daher macht es absolut keinen Performanceunterschied, ob man nun mit 50 Zeichen geizt oder einfach 255 Zeichen einräumt.

Hat jemand vielleicht technische Hintergrundinformationen?

Viele Grüße

Christoph
Mitglied: Biber
05.08.2006 um 14:19 Uhr
Moin bvsn,

tja, wie soll ich sagen, ihr habt beide in gewisser Weise Recht und auch Unrecht.

Nicht ausdrücklich auf ACCESS bezogen dazu folgendes:
Richtig ist, dass VARCHAR(n)-Felder im Gegensatz zu CHAR(n) "nur" den Speicherplatz verbrauchen, der dem Inhalt entspricht.

Also 5 Byte, wenn Du den String "Hallo" in einem VARCHAR(255)-Feld speicherst.
Dazu kommt eine Offset/Pointer-Information, in der hinterlegt ist, wo denn tatsächlich dieser String "Hallo" gespeichert ist und wie lang er ist.

Nun der Pferdefuss.
Wenn Deine Datentabellen eine "normale" Änderungsfrequenz haben und irgendwann auch aus dem 5-Byte-String "Hallo" ein String "Tach, ich bin der Biber" wird, dann kann dieser String nicht mehr an/in demselben Speicherort untergebracht werden, in dem die 5-"Hallo"-Byte gespeichert wurden.

Der neue String wird anderswo gespeichert, der Zeiger auf den String aktualisiert und auf den String "Hallo" zeigt nichts mehr... dieser Bereich ist ungenutzt/tot/frei, je nach Sichtweise.

Denn es ist ja höchst unwahrscheinlich, das irgendein anderes VARCHAR-Feld irgendwann mal genau 5 Byte benötigt und diesen Freiraum verwenden kann.

Bei hoher Änderungshäufigkeit in VARCHAR-Feldern steigt also der verschwendete Speicherplatz durch "ehemalige" Feldinhalte, die Fragmentierung und der interner Verwaltungsaufwand für die ganze Verpointerung.

Auch (aber nicht nur) deshalb gibt es bei Datenbanken die Möglichkeit der "Reorganisation".

Meine Faustregeln (mit denen ich bisher gut gefahren bin) bei VarChar-Feldern:
- VARCHAR-Felder kleiner 50 sind Bullshit ineffizient.
Unter 50 Zeichen Länge lieber CHAR-Felder mit fester Länge.

- wenn Varchar-Felder für Deine Applikation nötig/sinnvoll sind, diese immer an das Ende der Tabellenstruktur stellen. Denn ein Zugriff auf ein Feld, dass in der Reihenfolge NACH dem VARCHAR-Feld kommt, ist erst nach einer Längenberechnung des VarChar-Feldes möglich.

Gruß
Biber
Bitte warten ..
Mitglied: bvsn
08.09.2006 um 08:35 Uhr
Oh, ich habe eben erst gesehen, dass auf meine Frage doch noch geantwortet wurde. Habe scheinbar keine Benachrichtigung hierfür erhalten. Ich danke dir für deine sehr ausführliche Information und werde die Hinweise berücksichtigen.

Gruß

Christoph
Bitte warten ..
Heiß diskutierte Inhalte
Sicherheit
Verpackter Laptop entwendet
r0x3llVor 1 TagFrageSicherheit10 Kommentare

Hallo. Mir wurde aus dem Büro ein noch verpackter Dell XPS Laptop mit einem Wert von ca 3.500€ gestohlen. Kann man da was orten? ...

Windows 10
Netzwerkzugriff intern extern blockiert nach Aufbau NordVPN Verbindung
gelöst Slavik-10Vor 1 TagFrageWindows 1030 Kommentare

hallo Leute, ich habe mir vor kurzem ein VPN Anbieter bestellt. Das Problem an der ganzen Sache ist, sobald eine VPN Verbindung zu einem ...

Off Topic
Namenskonzept Kundengeräte
bitnarratorVor 1 TagFrageOff Topic5 Kommentare

Hallo, ich möchte gerne einmal die Diskussion anstoßen, weil ich eine hier in diese Richtung noch nichts gefunden habe. Es geht um die Bennenung ...

Netzwerkgrundlagen
Router für neues Heimnetzwerk - was will man 2021 haben?
billy01Vor 1 TagFrageNetzwerkgrundlagen7 Kommentare

Guten Abend zusammen, nachdem sich bei mir viel getan hat, stehe ich nun vor einem Umzug und dem Neuaufbau meines Heimnetzwerkes. Also weg von ...

Windows Server
Kein Internetzugriff bei einem Domänenclient
KerberoVor 1 TagFrageWindows Server15 Kommentare

Hallo community, ich habe ein ganz komisches Verhalten eines Clients bei mir. Ich habe eine kleine Domäne (6 Clients und ein Windows Server 2016 ...

LAN, WAN, Wireless
2x Fritzbox 7590 mit separatem DSL über WAN verbinden
gelöst FailixVor 19 StundenFrageLAN, WAN, Wireless19 Kommentare

Liebes Administrator Forum, Ich bin schon länger passiver Lese und habe mich jetzt entschlossen mit einer Frage den ersten Post hier zu schreiben. Über ...

LAN, WAN, Wireless
Cat 7 Patchkabel mit nur 11MBits im Download
gelöst RickHHVor 16 StundenFrageLAN, WAN, Wireless7 Kommentare

Moin zusammen, ich habe mir soeben ein paar Patchkabel (aus einem Cat 7 Kabel) fertig gemacht. Die Belegung ist: 1 weiß/grün 2 grün 3 weiß/orange 4 blau 5 weiß/blau ...

DNS
Network Scanner zeigt falschen Hostname an
gelöst vafk18Vor 19 StundenFrageDNS10 Kommentare

Ich habe in meinem Netzwerk 3 Fritzboxen im Betrieb. Die Fritzboxen haben in den Einstellungen als Namen "fb7270", "fb7369" und "fb7412". Jede Fritzbox hat ...