带有 IN 子句的区分大小写的搜索查询 - SQL 服务器

Case sensitive search query with IN clause - SQL Server

我想在 SQL 服务器环境中进行区分大小写的搜索。每当我使用如下所示的单独查询时,它都工作正常:

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;

但是当我使用如下 IN 子句时如何实现此功能:

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

就像您做的 2 个示例一样,使用 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');