SQL Server ->> 字符串对比

今天同事问我关于SQL Server在字符串尾随着空格时进行字符串对比的做法。关于这个问题正好在这里讲一下,就是SQL Server是按照ANSI/ISO SQL-92中的定义做字符串对比的。

KB316626中已经做了阐述,就是SQL Server对待这种有尾随空格的字符是会做自动截断尾随空格再对比的。

这里做个实验吧

SELECT * FROM (
SELECT 'A' A UNION ALL
SELECT 'A ' UNION ALL
SELECT 'A  ' UNION ALL
SELECT 'A                           ') A
WHERE A = 'A'

SELECT A, COUNT(*) FROM (
SELECT 'A' A UNION ALL
SELECT 'A ' UNION ALL
SELECT 'A  ' UNION ALL
SELECT 'A                           ') A
GROUP BY A

SELECT A FROM (
SELECT 'A' A UNION ALL
SELECT 'A ' UNION ALL
SELECT 'A  ' UNION ALL
SELECT 'A                           ') A
WHERE A like 'A %'

上面这段代码会返回下面的结果

 

可以看到SQL Server在做字符串对比和排序(其实排序也需要做字符串对比)是会截断尾随空格的,而在做LIKE匹配的时候则例外。

 

那如果是空格开头呢?这个肯定是没有截断起始空格的。再做一个实验。

SELECT * FROM (
SELECT ' A' A UNION ALL
SELECT 'A ' UNION ALL
SELECT '  A  ') A
WHERE A = 'A'


SELECT A, COUNT(*) FROM (
SELECT ' A' A UNION ALL
SELECT 'A ' UNION ALL
SELECT '  A  ' UNION ALL
SELECT '   A                           ') A
GROUP BY A

上面这段代码会返回下面的结果

 

posted @ 2015-11-18 16:15  Jerry_Chen  阅读(4875)  评论(0编辑  收藏  举报