ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 全文检索的转义

全文检索的转义

原创 Linux操作系统 作者:space6212 时间:2019-07-20 09:24:01 0 删除 编辑

在全文检索中有很多保留字符或保留词,如果不对这些作转义处理,则会导致查询不准确,如:


SQL> select sku from ITEM where ITEM_TYPE='p' and contains(SKU,'CN-A64-02-398-00')>0 and rownum<10;

SKU
--------------------------------------------------------------------------------
ISRC:CN-F29-2000-0051-0/V.J9
ISRC:CN-F29-2000-0036-0/V.J9
ISRC:CN-F29-03-0103-0/V.G2
ISRC:CN-F29-03-0057-0/V.G2
ISRC:CN-F28-03-309-0/A.J6
ISRC:CN-H10-05-0047-0/V.J9
ISRC:CN-H10-05-0046-0/V.J9
ISRC:CN-H10-05-0045-0/V.J9
ISRC:CN-H03-01-0015-0/V.R

9 rows selected

实际上,这不是我们想要的结果,引起这个的原因是字符串中包含'-',这个的含义是minus,这个查询实际上等同于:

select sku from ITEM where ITEM_TYPE='p' and contains(SKU,'CN')>0

minus

select sku from ITEM where ITEM_TYPE='p' and contains(SKU,'A64')>0

........

为了得到正确的结果,我们需要对'-'进行转义。

全文检索的转义有两种方法:和{}

其中''转义紧接着''的单个字符,{}转义包含在'{}'的所有特殊符号。

本例可以转换为:

SQL> select sku from ITEM where ITEM_TYPE='p' and contains(SKU,'{CN-A64-02-398-00}')>0 and rownum<10;

SKU
--------------------------------------------------------------------------------
ISRC:CN-A64-02-398-00/V.G4

SQL> select sku from ITEM where ITEM_TYPE='p' and contains(SKU,'CN-A64-02-398-00')>0 and rownum<10;

SKU
--------------------------------------------------------------------------------
ISRC:CN-A64-02-398-00/V.G4

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/231499/viewspace-63712/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 配置全文检索
请登录后发表评论 登录
全部评论

注册时间:2005-01-25

  • 博文量
    245
  • 访问量
    168757