-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathpg_bigm--1.2.sql
114 lines (100 loc) · 4.15 KB
/
pg_bigm--1.2.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
-- complain if script is sourced in psql, rather than via CREATE EXTENSION
\echo Use "CREATE EXTENSION pg_bigm" to load this file. \quit
CREATE FUNCTION show_bigm(text)
RETURNS _text
AS 'MODULE_PATHNAME'
LANGUAGE C STRICT IMMUTABLE;
CREATE FUNCTION bigm_similarity(text, text)
RETURNS float4
AS 'MODULE_PATHNAME'
LANGUAGE C STRICT IMMUTABLE;
CREATE FUNCTION bigm_similarity_op(text,text)
RETURNS bool
AS 'MODULE_PATHNAME'
LANGUAGE C STRICT STABLE; -- stable because depends on pg_bigm.similarity_limit
CREATE OPERATOR =% (
LEFTARG = text,
RIGHTARG = text,
PROCEDURE = bigm_similarity_op,
COMMUTATOR = '=%',
RESTRICT = contsel,
JOIN = contjoinsel
);
-- support functions for gin
CREATE FUNCTION gin_extract_value_bigm(text, internal)
RETURNS internal
AS 'MODULE_PATHNAME'
LANGUAGE C IMMUTABLE STRICT;
CREATE FUNCTION gin_extract_query_bigm(text, internal, int2, internal, internal, internal, internal)
RETURNS internal
AS 'MODULE_PATHNAME'
LANGUAGE C IMMUTABLE STRICT;
CREATE FUNCTION gin_bigm_consistent(internal, int2, text, int4, internal, internal, internal, internal)
RETURNS bool
AS 'MODULE_PATHNAME'
LANGUAGE C IMMUTABLE STRICT;
CREATE FUNCTION gin_bigm_compare_partial(text, text, int2, internal)
RETURNS bool
AS 'MODULE_PATHNAME'
LANGUAGE C IMMUTABLE STRICT;
CREATE FUNCTION bigmtextcmp(text, text)
RETURNS int4
AS 'MODULE_PATHNAME'
LANGUAGE C STRICT IMMUTABLE;
-- create the operator class for gin
CREATE OPERATOR CLASS gin_bigm_ops
FOR TYPE text USING gin
AS
OPERATOR 1 pg_catalog.~~ (text, text),
OPERATOR 2 =% (text, text),
FUNCTION 1 bigmtextcmp (text, text),
FUNCTION 2 gin_extract_value_bigm (text, internal),
FUNCTION 3 gin_extract_query_bigm (text, internal, int2, internal, internal, internal, internal),
FUNCTION 4 gin_bigm_consistent (internal, int2, text, int4, internal, internal, internal, internal),
FUNCTION 5 gin_bigm_compare_partial (text, text, int2, internal),
STORAGE text;
CREATE FUNCTION likequery(text)
RETURNS text
AS 'MODULE_PATHNAME'
LANGUAGE C STRICT IMMUTABLE;
CREATE FUNCTION pg_gin_pending_stats(index regclass, OUT pages int4, OUT tuples int8)
RETURNS record
AS 'MODULE_PATHNAME'
LANGUAGE C STRICT IMMUTABLE;
/* triConsistent function is available only in 9.4 or later */
DO $$
DECLARE
pgversion INTEGER;
BEGIN
SELECT current_setting('server_version_num')::INTEGER INTO pgversion;
IF pgversion >= 90400 THEN
CREATE FUNCTION gin_bigm_triconsistent(internal, int2, text, int4, internal, internal, internal)
RETURNS "char"
AS 'MODULE_PATHNAME'
LANGUAGE C IMMUTABLE STRICT;
ALTER OPERATOR FAMILY gin_bigm_ops USING gin ADD
FUNCTION 6 (text, text) gin_bigm_triconsistent (internal, int2, text, int4, internal, internal, internal);
END IF;
END;
$$;
/* Label whether the function is deemed safe for parallelism */
DO $$
DECLARE
pgversion INTEGER;
BEGIN
SELECT current_setting('server_version_num')::INTEGER INTO pgversion;
IF pgversion >= 90600 THEN
EXECUTE 'ALTER FUNCTION show_bigm(text) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION bigm_similarity(text, text) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION bigm_similarity_op(text, text) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION gin_extract_value_bigm(text, internal) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION gin_extract_query_bigm(text, internal, int2, internal, internal, internal, internal) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION gin_bigm_consistent(internal, int2, text, int4, internal, internal, internal, internal) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION gin_bigm_compare_partial(text, text, int2, internal) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION bigmtextcmp(text, text) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION likequery(text) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION pg_gin_pending_stats(index regclass) PARALLEL SAFE';
EXECUTE 'ALTER FUNCTION gin_bigm_triconsistent(internal, int2, text, int4, internal, internal, internal) PARALLEL SAFE';
END IF;
END;
$$;