Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/77.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
具有IN子句的区分大小写的搜索查询-SQL Server_Sql_Sql Server_Collate - Fatal编程技术网

具有IN子句的区分大小写的搜索查询-SQL Server

具有IN子句的区分大小写的搜索查询-SQL Server,sql,sql-server,collate,Sql,Sql Server,Collate,我想在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; 但是,当我使用下面这样的IN子句时,如何实现此功能: select * from

我想在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;
但是,当我使用下面这样的IN子句时,如何实现此功能:

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'); 

COLLATE子句可以防止使用索引,这样就可以添加
并在('Yes','No')
中标记,这样就可以通过索引查找和用于进一步筛选行的区分大小写的谓词来完成不敏感的搜索。