在使用其中一个oracle查询时,当我触发一个select命令时,条件类似于:
select * from table_name where contains(address,'"IN%" AND "BÖDEN%"') >0
再次,如果我在“IN”和“%”之间引入一个空格,我会得到正确的结果:
select * from table_name where contains(address,'"IN %" AND "BÖDEN%"') >0
还有一个场景:
相同类型的查询但如果“IN”替换为“IM”,则显示相应的结果.
select * from table_name where contains(address,'"IM%" AND "BÖDEN%"') >0
要么
select * from table_name where contains(address,'"IM %" AND "BÖDEN%"') >0
上述两个查询都给出了相同的结果.这也很明显.
因此我怀疑在甲骨文中有一些与“IN”有关的东西.
解决方法
IN关键字是默认Stoplist中的停用词,用于指定Oracle Text中未编入索引的单词.
另请在oracle中找到其他默认的英语停止词,供您参考Default Stop words