I recently read an article on Bitbucket about “Don’t start identity columns or sequences with large negative values” and it got me wondering if the author’s conclusion is correct.
data:image/s3,"s3://crabby-images/390b8/390b8f2ea89d6497949c87c0f0953575126069ed" alt=""
So I set up a lab to test his hypothesis. Each table has about 4 million rows.
data:image/s3,"s3://crabby-images/72b09/72b0914444d95b327f54bedaf59af751c1382626" alt=""
And to mimic the property of IDENTITY, I then rebuilt the indexes on the tables.
data:image/s3,"s3://crabby-images/e3336/e33365eaa7aeb1cd5b0e5ed4737b36d52957d856" alt=""
And then I executed these statements to see if there was a difference in compression, as the author stated.
data:image/s3,"s3://crabby-images/6ebf5/6ebf5518a88c6e2016540a1c7a8eb44f56b3281e" alt=""
And as I suspected, there was no difference.
The reason is how page- and row-compression is implemented.
See whitepapers here
And to be fair, I did the test again with ROW compression instead of PAGE compression and here is the result
data:image/s3,"s3://crabby-images/555da/555da996be56fe7aeaf96ad9b153f9456efa2cab" alt=""
Again, there is no difference. The miniscule 8KB is within the error margin.