Jump to content
  • entries
    292
  • comments
    368
  • views
    59882

Why Max Record Length is 8060 bytes


antonch

491 views

 Share

Σήμερα ένας αγαπητός φίλος και συνάδελφος μου έκανε μια ερώτηση. Η στιγμή που μου την έκανε ήταν δύσκολη και δεν είχα την άνεση να του την απαντήσω. Του υποσχέθηκα όμως ότι θα το κάνω. Έτσι αυτό το Post είναι αφιερωμένο εξαιρετικά στο φίλο και συνάδελφο του οποίου η ερώτηση ήταν

"Αντώνη διαβάζω μέσα από το blog σου ότι το μέγιστο record length που μπορώ να έχω μέσα σε μια σελίδα και κατά συνέπεια μέσα σε κάθε πίνακα είναι 8060 bytes. Όμως αυτό δεν μου βγαίνει με τα μαθηματικά. Διότι όπως λες μια σελίδα είναι 8192 bytes από τα οποία αφαιρούμε 96 bytes σαν page header και υπάρχει και το page slot array(offset) στο οποίο φαίνεται η σειρά με την οποία έχουν μπει τα records στην σελίδα. Αν αφαιρέσω τα 96 bytes του header μου μένουν 8096 bytes μέχρι τα 8060 μου λείπουν 36 bytes. Πόσο τελικά είναι αυτό το page slot array (offset);"

Λοιπόν έχουμε και λέμε ή λέμε και έχουμε:

8060 bytes είναι το max record length αυτό είναι αδιαμφισβήτητο.

8192 bytes είναι το μέγεθος της σελίδας και αυτό είναι αδιαμφισβήτητο.

96 bytes είναι το μέγεθος του page header και αυτό είναι αδιαμφισβήτητο.

Άρα έχω υπόλοιπο 8096 bytes.

Οπότε 8096 - 8060 = 36 bytes που πρέπει να δούμε που πάνε.

Για κάθε γραμμή έχω κάποια επιπλέον overheads

14 bytes για την περίπτωση που έχω snapshot isolation level.

2 bytes για το row status

2 bytes στα οποία υπάρχει ο μέγεθος των fixed lenght fields

2 bytes στα οποία υπάρχει ο αριθμός των πεδίων που υπάρχουν στην γραμμή.

1 byte για τα NULL bitmaps

2 bytes για τον αριθμό των variable lenght fields

11 bytes για τον forward record pointer

και

2 bytes για το page slot array (offset)

Άρα στο σύνολο έχω 36

Οπότε 36 - 36 = 0 bytes

Θυμάσε Νίκο μου όταν σου είπα δες πως αποθηκεύεται η γραμμή;

 Share

1 Comment


Recommended Comments

Guest
Add a comment...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Loading...
×
×
  • Create New...