Hello Devz,
Today I had an issue with the performance of a SQL stored procedure. This procedure was supposed to delete a few millions rows in a table. But it was quite slow… So after optimizing the query, I looked at the database itself.
Having an indexed primary key is important but the level of fragmentation of the index is something important as well.
data:image/s3,"s3://crabby-images/1be5d/1be5d17ed35686dc1bfc575143fd10684d0927e5" alt="indexed primary key on sql table"
indexed primary key on sql table
If you righ click on your index, and check the properties, then select Fragmentation, you can see the level of fragmentation of this index:
data:image/s3,"s3://crabby-images/b1a0d/b1a0d2710a310e2d3b5b18f356ae0316fc83dbc1" alt="fragmentation level on an index in a sql table"
fragmentation level on an index in a sql table
As you can see here the level of fragmentation is very important. All you have to do in that case it to Rebuild the index:
data:image/s3,"s3://crabby-images/18181/18181dead83c4d47d6ca54a8f1b64c5c9a91b252" alt="rebuild index of a fragmented primary key in sql table"
rebuild index of a fragmented primary key in sql table
And now the performance will be way better…
data:image/s3,"s3://crabby-images/6edb7/6edb7c11f38f1d14b4b93f5529490993e0570490" alt="defragmented index on a primary key of sql table"
defragmented index on a primary key of sql table
Happy coding! 🙂