pg_similarity

pg_similarity

pg_similarity : support similarity queries

Overview

IDExtensionPackageVersionCategoryLicenseLanguage
1840
pg_similarity
pg_similarity
1.0
RAG
BSD 3-Clause
C
AttributeHas BinaryHas LibraryNeed LoadHas DDLRelocatableTrusted
--s-d-r
No
Yes
No
Yes
yes
no
Relationships
See Also
vector
smlar
fuzzystrmatch
pg_trgm
vchord
pg_bigm
citext
unaccent

Packages

TypeRepoVersionPG Major CompatibilityPackage PatternDependencies
EXT
MIXED
1.0
18
17
16
15
14
pg_similarity-
RPM
PIGSTY
1.0
18
17
16
15
14
pg_similarity_$v-
DEB
PGDG
1.0
18
17
16
15
14
postgresql-$v-similarity-
Linux / PGPG18PG17PG16PG15PG14
el8.x86_64
PGDG 1.0
PIGSTY 1.0
PIGSTY 1.0
PIGSTY 1.0
PIGSTY 1.0
el8.aarch64
PGDG 1.0
PIGSTY 1.0
PIGSTY 1.0
PIGSTY 1.0
PIGSTY 1.0
el9.x86_64
PGDG 1.0
PIGSTY 1.0
PIGSTY 1.0
PIGSTY 1.0
PIGSTY 1.0
el9.aarch64
PGDG 1.0
PIGSTY 1.0
PIGSTY 1.0
PIGSTY 1.0
PIGSTY 1.0
el10.x86_64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
el10.aarch64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
d12.x86_64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
d12.aarch64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
d13.x86_64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
d13.aarch64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
u22.x86_64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
u22.aarch64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
u24.x86_64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
u24.aarch64
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PGDG 1.0
PackageVersionOSORGSIZEFile URL
pg_similarity_181.0el8.x86_64pgdg43.2 KiBpg_similarity_18-1.0-3PGDG.rhel8.x86_64.rpm
pg_similarity_181.0el8.x86_64pigsty44.9 KiBpg_similarity_18-1.0-2PIGSTY.el8.x86_64.rpm
pg_similarity_181.0el8.aarch64pgdg40.7 KiBpg_similarity_18-1.0-3PGDG.rhel8.aarch64.rpm
pg_similarity_181.0el8.aarch64pigsty43.0 KiBpg_similarity_18-1.0-2PIGSTY.el8.aarch64.rpm
pg_similarity_181.0el9.x86_64pgdg42.6 KiBpg_similarity_18-1.0-3PGDG.rhel9.x86_64.rpm
pg_similarity_181.0el9.x86_64pigsty41.9 KiBpg_similarity_18-1.0-2PIGSTY.el9.x86_64.rpm
pg_similarity_181.0el9.aarch64pgdg41.2 KiBpg_similarity_18-1.0-3PGDG.rhel9.aarch64.rpm
pg_similarity_181.0el9.aarch64pigsty40.6 KiBpg_similarity_18-1.0-2PIGSTY.el9.aarch64.rpm
pg_similarity_181.0el10.x86_64pgdg43.6 KiBpg_similarity_18-1.0-3PGDG.rhel10.x86_64.rpm
pg_similarity_181.0el10.x86_64pigsty42.3 KiBpg_similarity_18-1.0-2PIGSTY.el10.x86_64.rpm
pg_similarity_181.0el10.aarch64pgdg42.3 KiBpg_similarity_18-1.0-3PGDG.rhel10.aarch64.rpm
pg_similarity_181.0el10.aarch64pigsty41.0 KiBpg_similarity_18-1.0-2PIGSTY.el10.aarch64.rpm
postgresql-18-similarity1.0d12.x86_64pgdg98.6 KiBpostgresql-18-similarity_1.0-9.pgdg12+1_amd64.deb
postgresql-18-similarity1.0d12.aarch64pgdg96.2 KiBpostgresql-18-similarity_1.0-9.pgdg12+1_arm64.deb
postgresql-18-similarity1.0d13.x86_64pgdg98.5 KiBpostgresql-18-similarity_1.0-9.pgdg13+1_amd64.deb
postgresql-18-similarity1.0d13.aarch64pgdg96.2 KiBpostgresql-18-similarity_1.0-9.pgdg13+1_arm64.deb
postgresql-18-similarity1.0u22.x86_64pgdg98.4 KiBpostgresql-18-similarity_1.0-9.pgdg22.04+1_amd64.deb
postgresql-18-similarity1.0u22.aarch64pgdg96.2 KiBpostgresql-18-similarity_1.0-9.pgdg22.04+1_arm64.deb
postgresql-18-similarity1.0u24.x86_64pgdg97.5 KiBpostgresql-18-similarity_1.0-9.pgdg24.04+1_amd64.deb
postgresql-18-similarity1.0u24.aarch64pgdg94.9 KiBpostgresql-18-similarity_1.0-9.pgdg24.04+1_arm64.deb
PackageVersionOSORGSIZEFile URL
pg_similarity_171.0el8.x86_64pigsty44.8 KiBpg_similarity_17-1.0-2PIGSTY.el8.x86_64.rpm
pg_similarity_171.0el8.aarch64pigsty42.9 KiBpg_similarity_17-1.0-2PIGSTY.el8.aarch64.rpm
pg_similarity_171.0el9.x86_64pigsty42.0 KiBpg_similarity_17-1.0-2PIGSTY.el9.x86_64.rpm
pg_similarity_171.0el9.aarch64pigsty40.6 KiBpg_similarity_17-1.0-2PIGSTY.el9.aarch64.rpm
pg_similarity_171.0el10.x86_64pgdg43.6 KiBpg_similarity_17-1.0-3PGDG.rhel10.x86_64.rpm
pg_similarity_171.0el10.x86_64pigsty42.3 KiBpg_similarity_17-1.0-2PIGSTY.el10.x86_64.rpm
pg_similarity_171.0el10.aarch64pgdg42.3 KiBpg_similarity_17-1.0-3PGDG.rhel10.aarch64.rpm
pg_similarity_171.0el10.aarch64pigsty41.0 KiBpg_similarity_17-1.0-2PIGSTY.el10.aarch64.rpm
postgresql-17-similarity1.0d12.x86_64pgdg98.7 KiBpostgresql-17-similarity_1.0-9.pgdg12+1_amd64.deb
postgresql-17-similarity1.0d12.aarch64pgdg96.1 KiBpostgresql-17-similarity_1.0-9.pgdg12+1_arm64.deb
postgresql-17-similarity1.0d13.x86_64pgdg98.8 KiBpostgresql-17-similarity_1.0-9.pgdg13+1_amd64.deb
postgresql-17-similarity1.0d13.aarch64pgdg96.0 KiBpostgresql-17-similarity_1.0-9.pgdg13+1_arm64.deb
postgresql-17-similarity1.0u22.x86_64pgdg103.7 KiBpostgresql-17-similarity_1.0-9.pgdg22.04+1_amd64.deb
postgresql-17-similarity1.0u22.aarch64pgdg101.5 KiBpostgresql-17-similarity_1.0-9.pgdg22.04+1_arm64.deb
postgresql-17-similarity1.0u24.x86_64pgdg97.6 KiBpostgresql-17-similarity_1.0-9.pgdg24.04+1_amd64.deb
postgresql-17-similarity1.0u24.aarch64pgdg95.0 KiBpostgresql-17-similarity_1.0-9.pgdg24.04+1_arm64.deb
PackageVersionOSORGSIZEFile URL
pg_similarity_161.0el8.x86_64pigsty44.8 KiBpg_similarity_16-1.0-2PIGSTY.el8.x86_64.rpm
pg_similarity_161.0el8.aarch64pigsty43.0 KiBpg_similarity_16-1.0-2PIGSTY.el8.aarch64.rpm
pg_similarity_161.0el9.x86_64pigsty41.9 KiBpg_similarity_16-1.0-2PIGSTY.el9.x86_64.rpm
pg_similarity_161.0el9.aarch64pigsty40.5 KiBpg_similarity_16-1.0-2PIGSTY.el9.aarch64.rpm
pg_similarity_161.0el10.x86_64pgdg43.6 KiBpg_similarity_16-1.0-3PGDG.rhel10.x86_64.rpm
pg_similarity_161.0el10.x86_64pigsty42.3 KiBpg_similarity_16-1.0-2PIGSTY.el10.x86_64.rpm
pg_similarity_161.0el10.aarch64pgdg42.3 KiBpg_similarity_16-1.0-3PGDG.rhel10.aarch64.rpm
pg_similarity_161.0el10.aarch64pigsty41.0 KiBpg_similarity_16-1.0-2PIGSTY.el10.aarch64.rpm
postgresql-16-similarity1.0d12.x86_64pgdg98.7 KiBpostgresql-16-similarity_1.0-9.pgdg12+1_amd64.deb
postgresql-16-similarity1.0d12.aarch64pgdg96.1 KiBpostgresql-16-similarity_1.0-9.pgdg12+1_arm64.deb
postgresql-16-similarity1.0d13.x86_64pgdg98.6 KiBpostgresql-16-similarity_1.0-9.pgdg13+1_amd64.deb
postgresql-16-similarity1.0d13.aarch64pgdg96.2 KiBpostgresql-16-similarity_1.0-9.pgdg13+1_arm64.deb
postgresql-16-similarity1.0u22.x86_64pgdg103.6 KiBpostgresql-16-similarity_1.0-9.pgdg22.04+1_amd64.deb
postgresql-16-similarity1.0u22.aarch64pgdg101.5 KiBpostgresql-16-similarity_1.0-9.pgdg22.04+1_arm64.deb
postgresql-16-similarity1.0u24.x86_64pgdg97.5 KiBpostgresql-16-similarity_1.0-9.pgdg24.04+1_amd64.deb
postgresql-16-similarity1.0u24.aarch64pgdg95.1 KiBpostgresql-16-similarity_1.0-9.pgdg24.04+1_arm64.deb
PackageVersionOSORGSIZEFile URL
pg_similarity_151.0el8.x86_64pigsty45.9 KiBpg_similarity_15-1.0-2PIGSTY.el8.x86_64.rpm
pg_similarity_151.0el8.aarch64pigsty43.9 KiBpg_similarity_15-1.0-2PIGSTY.el8.aarch64.rpm
pg_similarity_151.0el9.x86_64pigsty44.1 KiBpg_similarity_15-1.0-2PIGSTY.el9.x86_64.rpm
pg_similarity_151.0el9.aarch64pigsty42.5 KiBpg_similarity_15-1.0-2PIGSTY.el9.aarch64.rpm
pg_similarity_151.0el10.x86_64pgdg45.8 KiBpg_similarity_15-1.0-3PGDG.rhel10.x86_64.rpm
pg_similarity_151.0el10.x86_64pigsty44.5 KiBpg_similarity_15-1.0-2PIGSTY.el10.x86_64.rpm
pg_similarity_151.0el10.aarch64pgdg44.2 KiBpg_similarity_15-1.0-3PGDG.rhel10.aarch64.rpm
pg_similarity_151.0el10.aarch64pigsty43.0 KiBpg_similarity_15-1.0-2PIGSTY.el10.aarch64.rpm
postgresql-15-similarity1.0d12.x86_64pgdg99.5 KiBpostgresql-15-similarity_1.0-9.pgdg12+1_amd64.deb
postgresql-15-similarity1.0d12.aarch64pgdg96.9 KiBpostgresql-15-similarity_1.0-9.pgdg12+1_arm64.deb
postgresql-15-similarity1.0d13.x86_64pgdg99.7 KiBpostgresql-15-similarity_1.0-9.pgdg13+1_amd64.deb
postgresql-15-similarity1.0d13.aarch64pgdg96.9 KiBpostgresql-15-similarity_1.0-9.pgdg13+1_arm64.deb
postgresql-15-similarity1.0u22.x86_64pgdg105.4 KiBpostgresql-15-similarity_1.0-9.pgdg22.04+1_amd64.deb
postgresql-15-similarity1.0u22.aarch64pgdg103.0 KiBpostgresql-15-similarity_1.0-9.pgdg22.04+1_arm64.deb
postgresql-15-similarity1.0u24.x86_64pgdg99.3 KiBpostgresql-15-similarity_1.0-9.pgdg24.04+1_amd64.deb
postgresql-15-similarity1.0u24.aarch64pgdg96.4 KiBpostgresql-15-similarity_1.0-9.pgdg24.04+1_arm64.deb
PackageVersionOSORGSIZEFile URL
pg_similarity_141.0el8.x86_64pigsty45.9 KiBpg_similarity_14-1.0-2PIGSTY.el8.x86_64.rpm
pg_similarity_141.0el8.aarch64pigsty43.9 KiBpg_similarity_14-1.0-2PIGSTY.el8.aarch64.rpm
pg_similarity_141.0el9.x86_64pigsty44.2 KiBpg_similarity_14-1.0-2PIGSTY.el9.x86_64.rpm
pg_similarity_141.0el9.aarch64pigsty42.5 KiBpg_similarity_14-1.0-2PIGSTY.el9.aarch64.rpm
pg_similarity_141.0el10.x86_64pgdg45.7 KiBpg_similarity_14-1.0-3PGDG.rhel10.x86_64.rpm
pg_similarity_141.0el10.x86_64pigsty44.5 KiBpg_similarity_14-1.0-2PIGSTY.el10.x86_64.rpm
pg_similarity_141.0el10.aarch64pgdg44.2 KiBpg_similarity_14-1.0-3PGDG.rhel10.aarch64.rpm
pg_similarity_141.0el10.aarch64pigsty43.0 KiBpg_similarity_14-1.0-2PIGSTY.el10.aarch64.rpm
postgresql-14-similarity1.0d12.x86_64pgdg99.5 KiBpostgresql-14-similarity_1.0-9.pgdg12+1_amd64.deb
postgresql-14-similarity1.0d12.aarch64pgdg96.8 KiBpostgresql-14-similarity_1.0-9.pgdg12+1_arm64.deb
postgresql-14-similarity1.0d13.x86_64pgdg99.4 KiBpostgresql-14-similarity_1.0-9.pgdg13+1_amd64.deb
postgresql-14-similarity1.0d13.aarch64pgdg96.9 KiBpostgresql-14-similarity_1.0-9.pgdg13+1_arm64.deb
postgresql-14-similarity1.0u22.x86_64pgdg105.4 KiBpostgresql-14-similarity_1.0-9.pgdg22.04+1_amd64.deb
postgresql-14-similarity1.0u22.aarch64pgdg102.8 KiBpostgresql-14-similarity_1.0-9.pgdg22.04+1_arm64.deb
postgresql-14-similarity1.0u24.x86_64pgdg99.3 KiBpostgresql-14-similarity_1.0-9.pgdg24.04+1_amd64.deb
postgresql-14-similarity1.0u24.aarch64pgdg96.4 KiBpostgresql-14-similarity_1.0-9.pgdg24.04+1_arm64.deb

Source

pig build pkg pg_similarity;		# build rpm

Install

Make sure PGDG and PIGSTY repo available:

pig repo add pgsql -u   # add both repo and update cache

Install this extension with pig:

pig install pg_similarity;		# install via package name, for the active PG version

pig install pg_similarity -v 18;   # install for PG 18
pig install pg_similarity -v 17;   # install for PG 17
pig install pg_similarity -v 16;   # install for PG 16
pig install pg_similarity -v 15;   # install for PG 15
pig install pg_similarity -v 14;   # install for PG 14

Create this extension with:

CREATE EXTENSION pg_similarity;

Usage

pg_similarity: Support similarity queries on PostgreSQL. Source: README.md

pg_similarity is an extension to support similarity queries on PostgreSQL. The implementation is tightly integrated in the RDBMS in the sense that it defines operators so instead of the traditional operators (= and <>) you can use ~~~ and ~!~ (any of these operators represents a similarity function).

pg_similarity has three main components:

  • Functions: a set of functions that implements similarity algorithms available in the literature. These functions can be used as UDFs and will be the base for implementing the similarity operators;
  • Operators: a set of operators defined at the top of similarity functions. They use similarity functions to obtain the similarity threshold and compare its value to a user-defined threshold to decide if it is a match or not;
  • Session Variables: a set of variables that store similarity function parameters. These variables can be defined at run time.

Functions and Operators

This extension supports a set of similarity algorithms. The most known algorithms are covered by this extension. You must be aware that each algorithm is suited for a specific domain. The following algorithms are provided:

  • L1 Distance (as known as City Block or Manhattan Distance)
  • Cosine Distance
  • Dice Coefficient
  • Euclidean Distance
  • Hamming Distance
  • Jaccard Coefficient
  • Jaro Distance
  • Jaro-Winkler Distance
  • Levenshtein Distance
  • Matching Coefficient
  • Monge-Elkan Coefficient
  • Needleman-Wunsch Coefficient
  • Overlap Coefficient
  • Q-Gram Distance
  • Smith-Waterman Coefficient
  • Smith-Waterman-Gotoh Coefficient
  • Soundex Distance
AlgorithmFunctionOperatorUse Index?Parameters
L1 Distanceblock(text, text) returns float8~++yespg_similarity.block_tokenizer, pg_similarity.block_threshold, pg_similarity.block_is_normalized
Cosine Distancecosine(text, text) returns float8~##yespg_similarity.cosine_tokenizer, pg_similarity.cosine_threshold, pg_similarity.cosine_is_normalized
Dice Coefficientdice(text, text) returns float8~-~yespg_similarity.dice_tokenizer, pg_similarity.dice_threshold, pg_similarity.dice_is_normalized
Euclidean Distanceeuclidean(text, text) returns float8~!!yespg_similarity.euclidean_tokenizer, pg_similarity.euclidean_threshold, pg_similarity.euclidean_is_normalized
Hamming Distancehamming(bit varying, bit varying) returns float8 / hamming_text(text, text) returns float8~@~nopg_similarity.hamming_threshold, pg_similarity.hamming_is_normalized
Jaccard Coefficientjaccard(text, text) returns float8~??yespg_similarity.jaccard_tokenizer, pg_similarity.jaccard_threshold, pg_similarity.jaccard_is_normalized
Jaro Distancejaro(text, text) returns float8~%%nopg_similarity.jaro_threshold, pg_similarity.jaro_is_normalized
Jaro-Winkler Distancejarowinkler(text, text) returns float8~@@nopg_similarity.jarowinkler_threshold, pg_similarity.jarowinkler_is_normalized
Levenshtein Distancelev(text, text) returns float8~==nopg_similarity.levenshtein_threshold, pg_similarity.levenshtein_is_normalized
Matching Coefficientmatchingcoefficient(text, text) returns float8~^^yespg_similarity.matching_tokenizer, pg_similarity.matching_threshold, pg_similarity.matching_is_normalized
Monge-Elkan Coefficientmongeelkan(text, text) returns float8~||nopg_similarity.mongeelkan_tokenizer, pg_similarity.mongeelkan_threshold, pg_similarity.mongeelkan_is_normalized
Needleman-Wunsch Coefficientneedlemanwunsch(text, text) returns float8~#~nopg_similarity.nw_threshold, pg_similarity.nw_is_normalized
Overlap Coefficientoverlapcoefficient(text, text) returns float8~**yespg_similarity.overlap_tokenizer, pg_similarity.overlap_threshold, pg_similarity.overlap_is_normalized
Q-Gram Distanceqgram(text, text) returns float8~~~yespg_similarity.qgram_threshold, pg_similarity.qgram_is_normalized
Smith-Waterman Coefficientsmithwaterman(text, text) returns float8~=~nopg_similarity.sw_threshold, pg_similarity.sw_is_normalized
Smith-Waterman-Gotoh Coefficientsmithwatermangotoh(text, text) returns float8~!~nopg_similarity.swg_threshold, pg_similarity.swg_is_normalized
Soundex Distancesoundex(text, text) returns float8~*~no

Parameters

The several parameters control the behavior of the pg_similarity functions and operators. They can be classified in three classes:

  • tokenizer: controls how the strings are tokenized. Valid values are alnum, gram, word, and camelcase. All tokens are lowercase. Default is alnum.
    • alnum: delimiters are any non-alphanumeric characters.
    • gram: an n-gram is a subsequence of length n, extracted using sliding-by-one technique.
    • word: delimiters are white space characters.
    • camelcase: delimiters are capitalized characters but they are also included as first token characters.
  • threshold: controls how flexible the result set will be. Values range from 0.0 to 1.0. Default is 0.7.
  • normalized: controls whether the similarity coefficient/distance is normalized (between 0.0 and 1.0) or not. Default is true.

Examples

Set parameters at run time:

SHOW pg_similarity.levenshtein_threshold;
-- 0.7

SET pg_similarity.levenshtein_threshold TO 0.5;

SET pg_similarity.cosine_tokenizer TO camelcase;

SET pg_similarity.euclidean_is_normalized TO false;

Simple tables for examples:

CREATE TABLE foo (a text);
INSERT INTO foo VALUES('Euler'),('Oiler'),('Euler Taveira de Oliveira'),('Maria Taveira dos Santos'),('Carlos Santos Silva');

CREATE TABLE bar (b text);
INSERT INTO bar VALUES('Euler T. de Oliveira'),('Euller'),('Oliveira, Euler Taveira'),('Sr. Oliveira');

Using similarity functions

SELECT a, b, cosine(a,b), jaro(a, b), euclidean(a, b) FROM foo, bar;

Using the levenshtein operator (~==)

SHOW pg_similarity.levenshtein_threshold;
-- 0.7

SELECT a, b, lev(a,b) FROM foo, bar WHERE a ~== b;
--              a             |          b           |   lev
-- ---------------------------+----------------------+----------
--  Euler                     | Euller               | 0.833333
--  Euler Taveira de Oliveira | Euler T. de Oliveira |     0.76

SET pg_similarity.levenshtein_threshold TO 0.5;

SELECT a, b, lev(a,b) FROM foo, bar WHERE a ~== b;
--              a             |          b           |   lev
-- ---------------------------+----------------------+----------
--  Euler                     | Euller               | 0.833333
--  Oiler                     | Euller               |      0.5
--  Euler Taveira de Oliveira | Euler T. de Oliveira |     0.76

Using the qgram operator (~~~)

SET pg_similarity.qgram_threshold TO 0.7;

SELECT a, b, qgram(a, b) FROM foo, bar WHERE a ~~~ b;
--              a             |            b            |  qgram
-- ---------------------------+-------------------------+----------
--  Euler                     | Euller                  |      0.8
--  Euler Taveira de Oliveira | Euler T. de Oliveira    |  0.77551
--  Euler Taveira de Oliveira | Oliveira, Euler Taveira | 0.807692

Comparing different operators

SELECT * FROM bar WHERE b ~@@ 'euler'; -- jaro-winkler operator
SELECT * FROM bar WHERE b ~~~ 'euler'; -- qgram operator
SELECT * FROM bar WHERE b ~== 'euler'; -- levenshtein operator
SELECT * FROM bar WHERE b ~## 'euler'; -- cosine operator
Last updated on