Σήμερα ένας αγαπητός φίλος και συνάδελφος μου έκανε μια ερώτηση. Η στιγμή που μου την έκανε ήταν δύσκολη και δεν είχα την άνεση να του την απαντήσω. Του υποσχέθηκα όμως ότι θα το κάνω. Έτσι αυτό το 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
Θυμάσε Νίκο μου όταν σου είπα δες πως αποθηκεύεται η γραμμή;