Click here to monitor SSC
SQLServerCentral is supported by Red Gate Software Ltd.
 
Log in  ::  Register  ::  Not logged in
 
 
 

Implicit Conversions warning

After adding an index,  ensuring that an index is actually used is probably the biggest win you will get in terms of performance in SqlServer.  There are many ways that an query can be non-sargable, and therefore not using an available index,  a common one is implicit (or even explicit) type conversion.

Within Denali ( or now SqlServer 2012 to give it its correct name) two new warnings have been added to the execution plan to help highlight this issue.  “Type conversion in expression ColumnExpression may affect "CardinalityEstimate" in query plan choice” and “Type conversion in expression ColumnExpression may affect "SeekPlan" in query plan choice” are now shown if a type conversion has happened and it is affecting , or could be , affecting performance.

To demonstrate both I will need to populate a small table

drop table nums
go
create table nums
(
IntCol Char(10)
)
go

insert into nums(IntCol)
Select top(10) row_number() over(order by (select null)) from sys.columns


Notice that the IntCol column is defined as a char(10) type.  If i now execute the following query
 
select * from nums where IntCol = 8
 
In the execution plan viewer, I will see this
image
 
There is a Yellow Exclamation Mark warning on the query it self and the warning is that the type conversion may affect CardinalityEstimate.  Its pretty obvious now what our potential problem is.
 
Additionally, if an index is created:
 
create index Idx1 on nums(IntCol)

and the Select statement re-executed,  this is shown..
 
 image
Even better , In layman's terms “You have an index, but i cant use it”.

Comments

Posted by Jason Brimhall on 18 October 2011

Thanks for the insight.  These could be very useful.

Leave a Comment

Please register or log in to leave a comment.