This article is half-done without your Comment! *** Please share your thoughts via Comment ***
In this post, I am going to share one of the important DBA script to find columns which have large object data types like VARBINARY, VARCHAR(MAX), NVARCHAR(MAX).
As a Database Administrator or Database Architecture, Why this is very important?
The best answer is: to avoid the problem of row overflow and internal page splitting in SQL Server.
SQL Server: What happened, when Row Overflow and Data Exceeding 8KB?
The size of the default data page is 8KB and SQL Server stores this kind of large data types in separate page even if they are in the same table.
In one of our database, I have found many VARCHAR(MAX) columns even that columns never require more than 255 characters.
Most of the Database Developers are doing this kind of mistake without aware of row-overflow and data exceeding issue.
The difference between VARCHAR(MAX) and VARCHAR(N) does not impact to data storage, but it makes lot difference in performance.
Using below script, you can find a list of columns which have large object data types:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
SELECT [s].[name] + '.' + [t].[name] AS TableName FROM [sys].[tables] AS t INNER JOIN [sys].[schemas] AS s ON [t].[schema_id] = [s].[schema_id] WHERE EXISTS ( SELECT 1 FROM [sys].[columns] AS c WHERE [c].[object_id] = [t].[object_id] AND [c].[max_length] = -1 AND [c].[system_type_id] IN ( 165, -- VARBINARY 167, -- VARCHAR 231 -- NVARCHAR ) ); |