oracle函数忽略大小写,Oracle中不区分大小写的search

在不使用全文索引的情况下,有三种主要的方法可以在Oracle中执行不区分大小写的search。

最终你select什么方法取决于你的个人情况。 要记住的主要是要提高性能,您必须正确索引不区分大小写的search。

1.一致地列出你的专栏和你的string。

您可以使用UPPER()或LOWER()强制所有的数据是相同的情况:

select * from my_table where upper(column_1) = upper('my_string');

要么

select * from my_table where lower(column_1) = lower('my_string');

如果column_1在upper(column_1)或lower(column_1) upper(column_1)没有索引,则可能会强制进行全表扫描。 为了避免这种情况,你可以创build一个基于函数的索引 。

create index my_index on my_table ( lower(column_1) );

如果你使用LIKE,那么你必须连接你正在search的string周围的% 。

select * from my_table where lower(column_1) LIKE lower('my_string') || '%';

这个SQL Fiddle演示了在所有这些查询中发生的事情。 请注意解释计划,它表明索引何时被使用,何时不被使用。

2.使用正则expression式。

从Oracle 10g起, REGEXP_LIKE()可用。 您可以指定_match_parameter_'i 'i' ,以执行不区分大小写的search。

为了将其用作平等运算符,您必须指定string的开始和结束,该string由克拉和美元符号表示。

select * from my_table where regexp_like(column_1, '^my_string$', 'i');

为了执行相同的LIKE,这些可以被删除。

select * from my_table where regexp_like(column_1, 'my_string', 'i');

请小心,因为您的string可能包含正则expression式引擎将解释不同的字符。

除了使用REGEXP_LIKE()之外, 这个SQL Fiddle显示了相同的示例输出。

3.在会话级别更改它。

NLS_SORT参数控制sorting和各种比较运算符(包括=和LIKE)的sorting顺序。 您可以指定一个二进制,不区分大小写,通过更改会话进行sorting。 这将意味着在该会话中执行的每个查询都将执行不区分大小写的参数。

alter session set nls_sort=BINARY_CI

如果您想要指定不同的语言,或者使用BINARY_AI进行不区分重音的search,则会有大量有关语言sorting和stringsearch的附加信息。

您还需要更改NLS_COMP参数; 去引用:

服从NLS_SORT参数的确切运算符和查询子句取决于NLS_COMP参数的值。 如果运算符或子句不符合由NLS_COMP确定的NLS_SORT值,则使用的sorting规则是BINARY。

NLS_COMP的默认值是BINARY; 但是,LINGUISTIC指定Oracle应该注意NLS_SORT的值:

WHERE子句和PL / SQL块中的所有SQL操作的比较应使用NLS_SORT参数中指定的语言sorting。 为了提高性能,还可以在要进行语言比较的列上定义语言索引。

所以,再一次,你需要改变会议

alter session set nls_comp=LINGUISTIC

如文档中所述,您可能需要创build一个语言索引来提高性能

create index my_linguistc_index on my_table (NLSSORT(column_1, 'NLS_SORT = BINARY_CI'));

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值