Commit 48c41fa9 authored by Tom Lane's avatar Tom Lane

Add a 64-bit hash function for type citext.

Amul Sul, reviewed by Hironobu Suzuki

Discussion: https://postgr.es/m/CAAJ_b947JjnNr9Cp45iNjSqKf6PA5mCTmKsRwPjows93YwQrmw@mail.gmail.com
parent a314c340
...@@ -3,7 +3,9 @@ ...@@ -3,7 +3,9 @@
MODULES = citext MODULES = citext
EXTENSION = citext EXTENSION = citext
DATA = citext--1.4.sql citext--1.4--1.5.sql \ DATA = citext--1.4.sql \
citext--1.5--1.6.sql \
citext--1.4--1.5.sql \
citext--1.3--1.4.sql \ citext--1.3--1.4.sql \
citext--1.2--1.3.sql citext--1.1--1.2.sql \ citext--1.2--1.3.sql citext--1.1--1.2.sql \
citext--1.0--1.1.sql citext--unpackaged--1.0.sql citext--1.0--1.1.sql citext--unpackaged--1.0.sql
......
/* contrib/citext/citext--1.5--1.6.sql */
-- complain if script is sourced in psql, rather than via ALTER EXTENSION
\echo Use "ALTER EXTENSION citext UPDATE TO '1.6'" to load this file. \quit
CREATE FUNCTION citext_hash_extended(citext, int8)
RETURNS int8
AS 'MODULE_PATHNAME'
LANGUAGE C STRICT IMMUTABLE PARALLEL SAFE;
ALTER OPERATOR FAMILY citext_ops USING hash ADD
FUNCTION 2 citext_hash_extended(citext, int8);
...@@ -153,6 +153,26 @@ citext_hash(PG_FUNCTION_ARGS) ...@@ -153,6 +153,26 @@ citext_hash(PG_FUNCTION_ARGS)
PG_RETURN_DATUM(result); PG_RETURN_DATUM(result);
} }
PG_FUNCTION_INFO_V1(citext_hash_extended);
Datum
citext_hash_extended(PG_FUNCTION_ARGS)
{
text *txt = PG_GETARG_TEXT_PP(0);
uint64 seed = PG_GETARG_INT64(1);
char *str;
Datum result;
str = str_tolower(VARDATA_ANY(txt), VARSIZE_ANY_EXHDR(txt), DEFAULT_COLLATION_OID);
result = hash_any_extended((unsigned char *) str, strlen(str), seed);
pfree(str);
/* Avoid leaking memory for toasted inputs */
PG_FREE_IF_COPY(txt, 0);
PG_RETURN_DATUM(result);
}
/* /*
* ================== * ==================
* OPERATOR FUNCTIONS * OPERATOR FUNCTIONS
......
# citext extension # citext extension
comment = 'data type for case-insensitive character strings' comment = 'data type for case-insensitive character strings'
default_version = '1.5' default_version = '1.6'
module_pathname = '$libdir/citext' module_pathname = '$libdir/citext'
relocatable = true relocatable = true
...@@ -222,6 +222,18 @@ SELECT citext_cmp('B'::citext, 'a'::citext) > 0 AS true; ...@@ -222,6 +222,18 @@ SELECT citext_cmp('B'::citext, 'a'::citext) > 0 AS true;
t t
(1 row) (1 row)
-- Check the citext_hash() and citext_hash_extended() function explicitly.
SELECT v as value, citext_hash(v)::bit(32) as standard,
citext_hash_extended(v, 0)::bit(32) as extended0,
citext_hash_extended(v, 1)::bit(32) as extended1
FROM (VALUES (NULL::citext), ('PostgreSQL'), ('eIpUEtqmY89'), ('AXKEJBTK'),
('muop28x03'), ('yi3nm0d73')) x(v)
WHERE citext_hash(v)::bit(32) != citext_hash_extended(v, 0)::bit(32)
OR citext_hash(v)::bit(32) = citext_hash_extended(v, 1)::bit(32);
value | standard | extended0 | extended1
-------+----------+-----------+-----------
(0 rows)
-- Do some tests using a table and index. -- Do some tests using a table and index.
CREATE TEMP TABLE try ( CREATE TEMP TABLE try (
name citext PRIMARY KEY name citext PRIMARY KEY
......
...@@ -222,6 +222,18 @@ SELECT citext_cmp('B'::citext, 'a'::citext) > 0 AS true; ...@@ -222,6 +222,18 @@ SELECT citext_cmp('B'::citext, 'a'::citext) > 0 AS true;
t t
(1 row) (1 row)
-- Check the citext_hash() and citext_hash_extended() function explicitly.
SELECT v as value, citext_hash(v)::bit(32) as standard,
citext_hash_extended(v, 0)::bit(32) as extended0,
citext_hash_extended(v, 1)::bit(32) as extended1
FROM (VALUES (NULL::citext), ('PostgreSQL'), ('eIpUEtqmY89'), ('AXKEJBTK'),
('muop28x03'), ('yi3nm0d73')) x(v)
WHERE citext_hash(v)::bit(32) != citext_hash_extended(v, 0)::bit(32)
OR citext_hash(v)::bit(32) = citext_hash_extended(v, 1)::bit(32);
value | standard | extended0 | extended1
-------+----------+-----------+-----------
(0 rows)
-- Do some tests using a table and index. -- Do some tests using a table and index.
CREATE TEMP TABLE try ( CREATE TEMP TABLE try (
name citext PRIMARY KEY name citext PRIMARY KEY
......
...@@ -89,6 +89,15 @@ SELECT citext_cmp('aardvark'::citext, 'aardVark'::citext) AS zero; ...@@ -89,6 +89,15 @@ SELECT citext_cmp('aardvark'::citext, 'aardVark'::citext) AS zero;
SELECT citext_cmp('AARDVARK'::citext, 'AARDVARK'::citext) AS zero; SELECT citext_cmp('AARDVARK'::citext, 'AARDVARK'::citext) AS zero;
SELECT citext_cmp('B'::citext, 'a'::citext) > 0 AS true; SELECT citext_cmp('B'::citext, 'a'::citext) > 0 AS true;
-- Check the citext_hash() and citext_hash_extended() function explicitly.
SELECT v as value, citext_hash(v)::bit(32) as standard,
citext_hash_extended(v, 0)::bit(32) as extended0,
citext_hash_extended(v, 1)::bit(32) as extended1
FROM (VALUES (NULL::citext), ('PostgreSQL'), ('eIpUEtqmY89'), ('AXKEJBTK'),
('muop28x03'), ('yi3nm0d73')) x(v)
WHERE citext_hash(v)::bit(32) != citext_hash_extended(v, 0)::bit(32)
OR citext_hash(v)::bit(32) = citext_hash_extended(v, 1)::bit(32);
-- Do some tests using a table and index. -- Do some tests using a table and index.
CREATE TEMP TABLE try ( CREATE TEMP TABLE try (
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment