Atlanta Custom Software Development 

 
   Search        Code/Page
 

User Login
Email

Password

 

Forgot the Password?
Services
» Web Development
» Maintenance
» Data Integration/BI
» Information Management
Programming
  Database
Automation
OS/Networking
Graphics
Links
Tools
» Regular Expr Tester
» Free Tools


Click here to copy the following block
create table #t ( c char(1))
insert #t values ('a')
insert #t values ('A')

select * from #t where c = 'A'
select * from #t where c = 'A' and ascii(c) = ascii('A')
select * from #t where c = 'A' and convert(varbinary, c) = convert(varbinary, 'A')

-- The solution presented above also shows a simple trick
-- that will enable the query to use an index ( assuming there
-- is one on the column 'c' ). This is done by not just doing convert
-- but also using the equality condition as is. Here is a template
-- of the query:
select * from tbl
where char_fld = @search_value and -- will allow Index seek
   convert( varbinary , char_fld ) = convert( varbinary , @search_value )

-- whereas the query below will work albeit slower & will perform
-- an index scan on char_fld. (assuming there is an index defined)
select * from tbl
where convert( varbinary , char_fld ) = convert( varbinary , @search_value )


Submitted By : Nayan Patel  (Member Since : 5/26/2004 12:23:06 PM)

Job Description : He is the moderator of this site and currently working as an independent consultant. He works with VB.net/ASP.net, SQL Server and other MS technologies. He is MCSD.net, MCDBA and MCSE. In his free time he likes to watch funny movies and doing oil painting.
View all (893) submissions by this author  (Birth Date : 7/14/1981 )


Home   |  Comment   |  Contact Us   |  Privacy Policy   |  Terms & Conditions   |  BlogsZappySys

© 2008 BinaryWorld LLC. All rights reserved.