一种方法是修改会话参数
NLS_SORT并
NLS_COMP:
SQL> SELECt Name FROM CollationTestTable WHERe NAME LIKE '%pe%';NAME--------------------------------------------------------------------------------pepeSQL> alter session set nls_sort=Latin_AI;Session alteredSQL> alter session set nls_comp=linguistic;Session alteredSQL> SELECt Name FROM CollationTestTable WHERe NAME LIKE '%pe%';NAME--------------------------------------------------------------------------------pepepépéPEPE
如另一个SO所示,您不能将LIKE运算符用于
NLSSORT(这是因为NLSSORT返回将用于排序的字节字符串,而LIKE仅适用于字符字符串)
更新: 虽然我将首选设置NLS参数,但也可以使用内置函数来获得相同的结果。几个例子:
SQL> SELECt Name 2 FROM CollationTestTable 3 WHERe upper(convert(NAME, 'US7ASCII')) 4 LIKE upper(convert('%pe%', 'US7ASCII'));NAME--------------------------------------------------------------------------------pepepépéPEPESQL> SELECt Name 2 FROM CollationTestTable 3 WHERe upper(translate(NAME, 'àâéèêìîòôùûÿ', 'aaeeeiioouuy')) 4 LIKE upper(translate('%pe%', 'àâéèêìîòôùûÿ', 'aaeeeiioouuy'));NAME-----------------------------------pepepépéPEPE


