Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
menu search
person
Welcome To Ask or Share your Answers For Others

Categories

Which one of the following queries is faster (LIKE vs CONTAINS)?

(以下哪个查询更快(LIKE vs CONTAINS)?)

SELECT * FROM table WHERE Column LIKE '%test%';

or

(要么)

SELECT * FROM table WHERE Contains(Column, "test");
  ask by user667429 translate from so

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
651 views
Welcome To Ask or Share your Answers For Others

1 Answer

The second (assuming you means CONTAINS , and actually put it in a valid query) should be faster, because it can use some form of index (in this case, a full text index).

(第二个(假设你的意思是CONTAINS ,实际上把它放在一个有效的查询中)应该更快,因为它可以使用某种形式的索引(在这种情况下,是一个全文索引)。)

Of course, this form of query is only available if the column is in a full text index.

(当然,只有列在全文索引中时,才能使用这种形式的查询。)

If it isn't, then only the first form is available.

(如果不是,那么只有第一种形式可用。)

The first query, using LIKE, will be unable to use an index, since it starts with a wildcard, so will always require a full table scan.

(使用LIKE的第一个查询将无法使用索引,因为它以通配符开头,因此始终需要全表扫描。)


The CONTAINS query should be:

(CONTAINS查询应该是:)

SELECT * FROM table WHERE CONTAINS(Column, 'test');

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
...