开发者

SQL Server CONTAINS with digits gives no results

开发者 https://www.devze.com 2022-12-24 07:18 出处:网络
I have a database table which is full-text indexed and i use the CONTAINS-function to perform a search-query on it.

I have a database table which is full-text indexed and i use the CONTAINS-function to perform a search-query on it.

When I do:

SELECT * FROM Plants WHERE CONTAINS(Plants.Description, '"Plant*" AND "one*"');

I get back all correct results matching a description with the words "Plant" and "one".

Some plant are named like "Plant 1", "Plant 2" etc. and this is the problem.

When i do this, i get no results:

SELECT * FROM Plants WH开发者_高级运维ERE CONTAINS(Plants.Description, '"Plant*" AND "1*"');

Anyone know why?


There is a list of commonly-used words that are not indexed in a keyword search, such as "and" and "the".

I believe the text "1" also appears in that list. Therefore it doesn't appear in the index, and can't be found with the CONTAINS clause.

If I recall correctly, there is an admin interface to allow you to edit that list of common words. I tried editing it once, a few years ago, and I recall having trouble telling the difference after I did.


Daan is correct. you need another * before the 1. Placing wildcards either side of a search term searches the entire string for the search term regardless of its position.

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号