I’d like to know how I can identify trailing spaces in a table. I’m using SQL Server 2008 and create the following table as a test
CREATE TABLE first_test_name
(
firstName varchar(255)
)
And then inserted a record like this:
insert into first_test_name (firstName)
values('Bob')
I then tried inserting a space and then adding a new record like this:
insert into first_test_name (firstName)
values('Bob ') -- just 1 space
And for a 3rd time,
insert into first_test_name (firstName)
values('Bob ') -- two spaces used this time.
Now if I query for for ‘Bob’ (no spaces), I still get a count of 3.
My query was:
select count(*) from first_test_name WHERE firstName = 'Bob'
Shouldn’t the answer have been 1?
Also, I used sp_help on this table and the value for “Trim Trailing Blanks” is set to no.
So why am I getting a count of 3? I was expecting just 1.
On a related note, if I search using this query
select * from first_test_name
where firstName like '% '
I then get the right answer of two rows found.
So just to reiterate, the question is why I get a count of 3 when searching for ‘Bob’.
Also, what does “Trim Trailing Blanks” mean in this case?
SQL Server ignores trailing spaces in most string comparisons.
This tells you the
ANSI_PADDINGoption set when the table was created.Here’s one way.
And to find ones with no trailing space