案例敏感的搜索查询与子句-SQL Server



我想在SQL Server环境中进行案例敏感搜索。每当我使用下面的单独查询时,它都可以正常工作:

select * from table1 where flag = 'Yes' COLLATE sql_latin1_general_cp1_cs_as;
select * from table1 where flag = 'No' COLLATE sql_latin1_general_cp1_cs_as;

但是,当我使用以下子句中的子句时,如何实现此功能:

select * from table1 where flag in ('Yes', 'No'); //This is returning all the flag vlaues like Yes, YES, NO, No

就像您的两个示例一样,使用COLLATE

SELECT *
FROM table1
WHERE flag COLLATE sql_latin1_general_cp1_cs_as IN ('Yes', 'No');

正确设置列整理,您已经完成了 - 永远!

ALTER TABLE table1 ALTER COLUMN flag varchar(3) COLLATE sql_latin1_general_cp1_cs_as

现在您可以简单地做:

select * from table1 where flag = 'Yes';
select * from table1 where flag in ('Yes', 'No'); 

相关内容

  • 没有找到相关文章

最新更新