Commit 27fddec1 authored by Tom Lane's avatar Tom Lane

Docs: add another example of creating a range type.

The "floatrange" example is a bit too simple because float8mi can be
used without any additional type conversion.  Add an example that does
have to account for that, and do some minor other wordsmithing.
parent e06b2e1d
...@@ -344,6 +344,12 @@ SELECT '[1.234, 5.678]'::floatrange; ...@@ -344,6 +344,12 @@ SELECT '[1.234, 5.678]'::floatrange;
function in this example. function in this example.
</para> </para>
<para>
Defining your own range type also allows you to specify a different
subtype B-tree operator class or collation to use, so as to change the sort
ordering that determines which values fall into a given range.
</para>
<para> <para>
If the subtype is considered to have discrete rather than continuous If the subtype is considered to have discrete rather than continuous
values, the <command>CREATE TYPE</> command should specify a values, the <command>CREATE TYPE</> command should specify a
...@@ -365,29 +371,40 @@ SELECT '[1.234, 5.678]'::floatrange; ...@@ -365,29 +371,40 @@ SELECT '[1.234, 5.678]'::floatrange;
</para> </para>
<para> <para>
Defining your own range type also allows you to specify a different In addition, any range type that is meant to be used with GiST or SP-GiST
subtype B-tree operator class or collation to use, so as to change the sort indexes should define a subtype difference, or <literal>subtype_diff</>,
ordering that determines which values fall into a given range. function. (The index will still work without <literal>subtype_diff</>,
but it is likely to be considerably less efficient than if a difference
function is provided.) The subtype difference function takes two input
values of the subtype, and returns their difference
(i.e., <replaceable>X</> minus <replaceable>Y</>) represented as
a <type>float8</> value. In our example above, the
function <function>float8mi</> that underlies the regular <type>float8</>
minus operator can be used; but for any other subtype, some type
conversion would be necessary. Some creative thought about how to
represent differences as numbers might be needed, too. To the greatest
extent possible, the <literal>subtype_diff</> function should agree with
the sort ordering implied by the selected operator class and collation;
that is, its result should be positive whenever its first argument is
greater than its second according to the sort ordering.
</para> </para>
<para> <para>
In addition, any range type that is meant to be used with GiST or SP-GiST indexes A less-oversimplified example of a <literal>subtype_diff</> function is:
should define a subtype difference, or <literal>subtype_diff</>, function.
(the index will still work without <literal>subtype_diff</>, but it is
likely to be considerably less efficient than if a difference function is
provided.) The subtype difference function takes two input values of the
subtype, and returns their difference (i.e., <replaceable>X</> minus
<replaceable>Y</>) represented as a <type>float8</> value. In our example
above, the function that underlies the regular <type>float8</> minus
operator can be used; but for any other subtype, some type conversion would
be necessary. Some creative thought about how to represent differences as
numbers might be needed, too. To the greatest extent possible, the
<literal>subtype_diff</> function should agree with the sort ordering
implied by the selected operator class and collation; that is, its result
should be positive whenever its first argument is greater than its second
according to the sort ordering.
</para> </para>
<programlisting>
CREATE FUNCTION time_subtype_diff(x time, y time) RETURNS float8 AS
'SELECT EXTRACT(EPOCH FROM (x - y))' LANGUAGE sql STRICT IMMUTABLE;
CREATE TYPE timerange AS RANGE (
subtype = time,
subtype_diff = time_subtype_diff
);
SELECT '[11:10, 23:00]'::timerange;
</programlisting>
<para> <para>
See <xref linkend="SQL-CREATETYPE"> for more information about creating See <xref linkend="SQL-CREATETYPE"> for more information about creating
range types. range types.
......
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