65 lines
1.9 KiB
SQL
65 lines
1.9 KiB
SQL
/* contrib/btree_gist/btree_gist--1.3--1.4.sql */
|
|
|
|
-- complain if script is sourced in psql, rather than via ALTER EXTENSION
|
|
\echo Use "ALTER EXTENSION btree_gist UPDATE TO '1.4'" to load this file. \quit
|
|
|
|
-- Add support for indexing macaddr8 columns
|
|
|
|
-- define the GiST support methods
|
|
CREATE FUNCTION gbt_macad8_consistent(internal,macaddr8,int2,oid,internal)
|
|
RETURNS bool
|
|
AS 'MODULE_PATHNAME'
|
|
LANGUAGE C IMMUTABLE STRICT;
|
|
|
|
CREATE FUNCTION gbt_macad8_compress(internal)
|
|
RETURNS internal
|
|
AS 'MODULE_PATHNAME'
|
|
LANGUAGE C IMMUTABLE STRICT;
|
|
|
|
CREATE FUNCTION gbt_macad8_fetch(internal)
|
|
RETURNS internal
|
|
AS 'MODULE_PATHNAME'
|
|
LANGUAGE C IMMUTABLE STRICT;
|
|
|
|
CREATE FUNCTION gbt_macad8_penalty(internal,internal,internal)
|
|
RETURNS internal
|
|
AS 'MODULE_PATHNAME'
|
|
LANGUAGE C IMMUTABLE STRICT;
|
|
|
|
CREATE FUNCTION gbt_macad8_picksplit(internal, internal)
|
|
RETURNS internal
|
|
AS 'MODULE_PATHNAME'
|
|
LANGUAGE C IMMUTABLE STRICT;
|
|
|
|
CREATE FUNCTION gbt_macad8_union(internal, internal)
|
|
RETURNS gbtreekey16
|
|
AS 'MODULE_PATHNAME'
|
|
LANGUAGE C IMMUTABLE STRICT;
|
|
|
|
CREATE FUNCTION gbt_macad8_same(gbtreekey16, gbtreekey16, internal)
|
|
RETURNS internal
|
|
AS 'MODULE_PATHNAME'
|
|
LANGUAGE C IMMUTABLE STRICT;
|
|
|
|
-- Create the operator class
|
|
CREATE OPERATOR CLASS gist_macaddr8_ops
|
|
DEFAULT FOR TYPE macaddr8 USING gist
|
|
AS
|
|
OPERATOR 1 < ,
|
|
OPERATOR 2 <= ,
|
|
OPERATOR 3 = ,
|
|
OPERATOR 4 >= ,
|
|
OPERATOR 5 > ,
|
|
FUNCTION 1 gbt_macad8_consistent (internal, macaddr8, int2, oid, internal),
|
|
FUNCTION 2 gbt_macad8_union (internal, internal),
|
|
FUNCTION 3 gbt_macad8_compress (internal),
|
|
FUNCTION 4 gbt_decompress (internal),
|
|
FUNCTION 5 gbt_macad8_penalty (internal, internal, internal),
|
|
FUNCTION 6 gbt_macad8_picksplit (internal, internal),
|
|
FUNCTION 7 gbt_macad8_same (gbtreekey16, gbtreekey16, internal),
|
|
STORAGE gbtreekey16;
|
|
|
|
ALTER OPERATOR FAMILY gist_macaddr8_ops USING gist ADD
|
|
OPERATOR 6 <> (macaddr8, macaddr8) ,
|
|
FUNCTION 9 (macaddr8, macaddr8) gbt_macad8_fetch (internal);
|