我有大写和小写字符的字符串,我怎么能忽略区分大小写。
我尝试过COLLET,UPPERCASE,LOWERCASE它不起作用。还有其他方法可以忽略吗?
试试这个:
WHERE UPPER(myColumn) = UPPER(myValue)
或者,当然:
WHERE LOWER(myColumn) = LOWER(myValue)
就像罗伯特·科克提到的那样,在两侧使用上部或下部。如果在使用大写/小写后连接不匹配,则可能是由于数据中的尾随空格。在这种情况下,您还可以使用trim来删除不需要的尾随空格
upper(trim(column1)) = upper(trim(column2))
要么
lower(trim(column1)) = lower(trim(column2))
上部和下部方法都可以,但如果您正在寻找更复杂的东西,请试试这个。
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