SQL Server Tips

Managing SQL Server Objects with SET Options

Updated
3 min read
Written by
Mark Varnas

Table of Contents 

Back to top 

What are the SET options?

SQL Server backward compatibility SET options allow legacy T-SQL code to run on newer SQL Server versions without changes while supporting ISO SQL standards for new development.

Briefly, they prevent applications that expect non-ISO behavior from breaking.

Why should you care about it?

Creating objects with these settings set to OFF is not advised. Should you later wish to add filtered indexes, indexed views, or other advanced features to tables used within these objects, they cause issues (break).

How to find SQL Server objects with set options?

You can find objects with QUOTED_IDENTIFIER or ANSI_NULLS OFF using the query below.


SELECT OBJECT_SCHEMA_NAME(o.object_id) AS SchemaName
	,OBJECT_NAME(o.object_id) AS ObjectName
	,o.type_desc AS ObjectType
FROM sys.objects AS o
WHERE 0 IN (
		OBJECTPROPERTY(o.object_id, 'ExecIsQuotedIdentOn')
		,OBJECTPROPERTY(o.object_id, 'ExecIsAnsiNullsOn')
		)

You can find varchar(n)/varbinary(n) columns with ANSI_PADDING OFF using the query below.


SELECT OBJECT_SCHEMA_NAME(t.object_id) AS SchemaName
	,OBJECT_NAME(t.object_id) AS ObjectName
	,c.name AS ColumnName
FROM sys.tables AS t
JOIN sys.columns AS c ON c.object_id = t.object_id
JOIN sys.types AS ty ON ty.system_type_id = c.system_type_id
	AND ty.user_type_id = c.user_type_id
WHERE c.is_ansi_padded = 0
	AND (
		(
			ty.name IN (
				'varbinary'
				,'varchar'
				)
			AND c.max_length <> - 1
			)
		OR (
			ty.name IN (
				'binary'
				,'char'
				)
			AND c.is_nullable = 1
			)
		)

How to fix them?

  1. Recreate the object from a session with QUOTED_IDENTIFER and ANSI_NULLS ON to change the persisted OFF setting to ON. Make sure the session setting is ON when executing DDL scripts.
  2. To change a persistent column ANSI_PADDING setting from OFF to ON, execute ALTER TABLEALTER COLUMN from an ANSI_PADDING ON session (specify the same definition as the existing column).

More information

Speak with a SQL Expert

In just 30 minutes, we will show you how we can eliminate your SQL Server headaches and provide 
operational peace of mind

Article by
Mark Varnas
Founder | CEO | SQL Veteran
Hey, I'm Mark, one of the guys behind Red9. I make a living performance tuning SQL Servers and making them more stable.

Discover More

SQL Server Health Check SQL Server Migrations & Upgrades SQL Server Performance Tuning SQL Server Security SQL Server Tips

Discover what clients are saying about Red9

Red9 has incredible expertise both in SQL migration and performance tuning.

The biggest benefit has been performance gains and tuning associated with migrating to AWS and a newer version of SQL Server with Always On clustering. Red9 was integral to this process. The deep knowledge of MSSQL and combined experience of Red9 have been a huge asset during a difficult migration. Red9 found inefficient indexes and performance bottlenecks that improved latency by over 400%.

Rich Staats 5 stars
Rich Staats
Cloud Engineer
MetalToad

Always willing to go an extra mile

Working with Red9 DBAs has been a pleasure. They are great team players and have an expert knowledge of SQL Server database administration. And are always willing to go the extra mile to get the project done.
5 stars
Evelyn A.
Sr. Database Administrator

Boosts server health and efficiency for enhanced customer satisfaction

Since adding Red9 to the reporting and DataWarehousing team, Red9 has done a good job coming up to speed on our environments and helping ensure we continue to meet our customer's needs. Red9 has taken ownership of our servers ensuring they remain healthy by monitoring and tuning inefficient queries.
5 stars
Andrew F.
Datawarehousing Manager
See more testimonials