Scenario: Download Script
You are working as Database Developer / SQL server Developer or T-SQL developer. The project you are working is to find and clean the data in database. You got this scenario where you have to find all the records in a database with leading or trailing spaces and then update that record. 
You need to check the values for all the columns which are char, nchar, varchar, nvarchar, text or ntext data type.
Solution:
We will be using cursor to find out all the records with leading or trailing space and then update them.We will trim the empty spaces from each value. As the process has to be done for each column, this can take long time to run if you your database is big and on top of that you have a lot of records which needs to be updated. 
Here are few suggestions
1) Comment out the Update statement from below code and only run the select, so get the record count how many records will be updated. Also you can verify the records to make sure.
2) Take the backup of database and restore in QA or UAT and run the script and validate all the results, By doing that you will get to know how much time it took for entire script to run.
3) if your script took long time, you can schedule it on weekends or off hours when you have less activity on SQL Server, specially on that server.
here is the code.
USE YourTestDB GO Declare @UpdateTo VARCHAR(100) DECLARE @DatabaseName VARCHAR(100) DECLARE @SchemaName VARCHAR(100) DECLARE @TableName VARCHAR(100) DECLARE @ColumnName VARCHAR(100) DECLARE @FullyQualifiedTableName VARCHAR(500) Declare @DataType VARCHAR(50) --Create Temp Table to Save Results IF OBJECT_ID('tempdb..#Results') IS NOT NULL DROP TABLE #Results CREATE TABLE #Results ( DatabaseName VARCHAR(100) ,SchemaName VARCHAR(100) ,TableName VARCHAR(100) ,ColumnName VARCHAR(100) ,ColumnDataType VARCHAR(50) ,TotalTableRowCount INT ,UpdatedRecordCount INT ) DECLARE Cur CURSOR FOR SELECT C.Table_CataLog ,C.Table_Schema ,C.Table_Name ,C.Column_Name ,'[' + C.Table_CataLog + ']' + '.[' + C.Table_Schema + '].' + '[' + C.Table_Name + ']' AS FullQualifiedTableName, C.Data_Type FROM information_schema.Columns C INNER JOIN information_Schema.Tables T ON C.Table_Name = T.Table_Name AND T.Table_Type = 'BASE TABLE' and (C.Data_Type like '%CHAR%' or C.Data_Type like '%Text%') OPEN Cur FETCH NEXT FROM Cur INTO @DatabaseName ,@SchemaName ,@TableName ,@ColumnName ,@FullyQualifiedTableName ,@DataType WHILE @@FETCH_STATUS = 0 BEGIN --Handle Text or NText Columns DECLARE @ColumnName1 VARCHAR(50) IF @DataType like '%Text%' BEGIN SET @ColumnName1='CAST('+@ColumnName + ' AS NVARCHAR(MAX))' END ELSE BEGIN SET @ColumnName1=@ColumnName END DECLARE @SQL NVARCHAR(MAX) = NULL DECLARE @UpdateSQL NVARCHAR(MAX) SET @SQL = ' Select ''' + @DatabaseName + ''' AS DatabaseName, ''' + @SchemaName + ''' AS TableName, ''' + @TableName + ''' AS SchemaName, ''' + @ColumnName + ''' AS ColumnName, ''' + @DataType + ''' AS ColumnName, (Select count(*) from ' + @FullyQualifiedTableName + ' With (Nolock)) AS TotalTableRowCount, count(*) as UpdatedRecordCount from ' + @FullyQualifiedTableName + 'With (Nolock) Where '+@ColumnName+' like ''% '''+ 'or '+@ColumnName+' like '' %''' Print @SQL INSERT INTO #Results EXEC (@SQL) --Prepare and Execute Update Statement SET @UpdateSQL='Update '+@FullyQualifiedTableName+' SET '+@ColumnName+'=LTRIM(RTRIM('+@ColumnName1+'))'+ ' Where '+@ColumnName+' like ''% '''+ 'or '+@ColumnName+' like '' %''' Print @UpdateSQL EXEC(@UpdateSQL) FETCH NEXT FROM Cur INTO @DatabaseName ,@SchemaName ,@TableName ,@ColumnName ,@FullyQualifiedTableName ,@DataType END CLOSE Cur DEALLOCATE Cur SELECT * from #Results Where UpdatedRecordCount<>0 --drop table #Results
The query will also return you Table Name, Schema Name, Column Name, Column Type, Total Table Record Count and Update Record Count.
How to remove leading and trailing spaces for all the columns in all the tables in SQL Server Database
 Check out our other posts on Data Analysis / Data Validation / Data Cleansing
- How to Search in all Columns for all tables in a database for Date Value in SQL Server
- How to Find Percentage of Null Values in every Column of all the Tables in SQL Server Database
- How to Find Percentage of Empty or Blank Values in every Column of all the Tables in SQL Server Database
- How to Get Row Count Of All The Tables In SQL Server Database
- How to search for a String in all Columns in all tables in SQL Server Database
- How to find and Replace Text in all the columns in all the tables in SQL server Database
- How to find values with Leading or Trailing Spaces in SQL Server Table
- How to Find Duplicate Records in All the Tables in SQL Server Database
- How to Find & Delete Duplicate Records on All Tables in SQL Server Database
- How to Generate Select all Columns with or Without Top X Rows From All Tables Query Dynamically in SQL Server
- Concatenate SQL Server Columns for each Table Query Dynamically in SQL Server
- How to List all Missing Identity Values for all Tables in SQL Server Database
- How to Find Max and Min Values for all the columns for all the tables in SQL Server Database



No comments:
Post a Comment
Note: Only a member of this blog may post a comment.