mirror of
https://github.com/postgres/postgres.git
synced 2025-07-27 12:41:57 +03:00
Handle equality operator in contrib/pg_trgm
Obviously, in order to equality operator be satisfiable, target string must contain all the trigrams of the search string. On this base, we implement equality operator in GiST/GIN indexes with recheck. Discussion: https://postgr.es/m/CAOBaU_YWwtT7tdggtROacjdOdeYHCz-tmSwuC-j-TOG-g97J0w%40mail.gmail.com Author: Julien Rouhaud Reviewed-by: Tom Lane, Alexander Korotkov, Georgios Kokolatos, Erik Rijkers
This commit is contained in:
@ -232,6 +232,7 @@ gtrgm_consistent(PG_FUNCTION_ARGS)
|
||||
case SimilarityStrategyNumber:
|
||||
case WordSimilarityStrategyNumber:
|
||||
case StrictWordSimilarityStrategyNumber:
|
||||
case EqualStrategyNumber:
|
||||
qtrg = generate_trgm(VARDATA(query),
|
||||
querysize - VARHDRSZ);
|
||||
break;
|
||||
@ -338,7 +339,8 @@ gtrgm_consistent(PG_FUNCTION_ARGS)
|
||||
#endif
|
||||
/* FALL THRU */
|
||||
case LikeStrategyNumber:
|
||||
/* Wildcard search is inexact */
|
||||
case EqualStrategyNumber:
|
||||
/* Wildcard and equal search are inexact */
|
||||
*recheck = true;
|
||||
|
||||
/*
|
||||
|
Reference in New Issue
Block a user