如何在Oracle数据库查询中忽略区分大小写

问题描述 投票:1回答:3

我有大写和小写字符的字符串,我怎么能忽略区分大小写。

我尝试过COLLET,UPPERCASE,LOWERCASE它不起作用。还有其他方法可以忽略吗?

sql oracle case-sensitive
3个回答
2
投票

试试这个:

WHERE UPPER(myColumn) = UPPER(myValue)

或者,当然:

WHERE LOWER(myColumn) = LOWER(myValue)

0
投票

就像罗伯特·科克提到的那样,在两侧使用上部或下部。如果在使用大写/小写后连接不匹配,则可能是由于数据中的尾随空格。在这种情况下,您还可以使用trim来删除不需要的尾随空格

upper(trim(column1)) = upper(trim(column2))

要么

lower(trim(column1)) = lower(trim(column2))

0
投票

上部和下部方法都可以,但如果您正在寻找更复杂的东西,请试试这个。

create table table_test (a varchar2(100));

insert into table_test values( 'ABC');
insert into table_test values( 'abc');
insert into table_test values( 'AbC');

alter session set NLS_COMP=LINGUISTIC; 
-- how to compare string 
alter session set NLS_SORT=BINARY_AI;  --//or alter session set NLS_SORT=BINARY_CI;  
-- how to sort string  
-- the magic starts here 
    select * from table_test where a = 'ABC'

并完整描述了不同的排序和比较方法:https://docs.oracle.com/cd/B28359_01/server.111/b28298/ch5lingsort.htm#CIHJBFAD

© www.soinside.com 2019 - 2024. All rights reserved.