1. 首页
  2. IT资讯

全文检索的转义

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

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.J9ISRC:CN-F29-2000-0036-0/V.J9ISRC:CN-F29-03-0103-0/V.G2ISRC:CN-F29-03-0057-0/V.G2ISRC:CN-F28-03-309-0/A.J6ISRC:CN-H10-05-0047-0/V.J9ISRC:CN-H10-05-0046-0/V.J9ISRC:CN-H10-05-0045-0/V.J9ISRC: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/,如需转载,请注明出处,否则将追究法律责任。

主题测试文章,只做测试使用。发布者:布吉卡,转转请注明出处:http://www.cxybcw.com/195731.html

联系我们

13687733322

在线咨询:点击这里给我发消息

邮件:1877088071@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code