mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-10-05 20:56:53 +02:00
674b22a2a4
PostgreSQL type extensions for IP and MAC addresses. I needed to record IP and MAC level ethernet addresses in a data base, and I really didn't want to store them as plain strings, with no enforced error checking, so I put together the accompanying code as my first experiment with adding a data type to PostgreSQL. I then thought that this might be useful to others, both directly and as a very simple example of how to do this sort of thing, so here it is, in the hope that it will be useful.
132 lines
2.3 KiB
SQL
132 lines
2.3 KiB
SQL
--
|
|
-- PostgreSQL code for IP addresses.
|
|
--
|
|
|
|
load '/usr/local/pgsql/modules/ip.so';
|
|
|
|
--
|
|
-- Input and output functions and the type itself:
|
|
--
|
|
|
|
create function ipaddr_in(opaque)
|
|
returns opaque
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
create function ipaddr_out(opaque)
|
|
returns opaque
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
create type ipaddr (
|
|
internallength = 8,
|
|
externallength = variable,
|
|
input = ipaddr_in,
|
|
output = ipaddr_out
|
|
);
|
|
|
|
--
|
|
-- The various boolean tests:
|
|
--
|
|
|
|
create function ipaddr_lt(ipaddr, ipaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
create function ipaddr_le(ipaddr, ipaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
create function ipaddr_eq(ipaddr, ipaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
create function ipaddr_ge(ipaddr, ipaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
create function ipaddr_gt(ipaddr, ipaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
create function ipaddr_ne(ipaddr, ipaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
create function ipaddr_like(ipaddr, ipaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/ip.so'
|
|
language 'c';
|
|
|
|
--
|
|
-- Now the operators. Note how some of the parameters to some
|
|
-- of the 'create operator' commands are commented out. This
|
|
-- is because they reference as yet undefined operators, and
|
|
-- will be implicitly defined when those are, further down.
|
|
--
|
|
|
|
create operator <= (
|
|
leftarg = ipaddr,
|
|
rightarg = ipaddr,
|
|
-- commutator = >,
|
|
-- negator = >,
|
|
procedure = ipaddr_le
|
|
);
|
|
|
|
create operator < (
|
|
leftarg = ipaddr,
|
|
rightarg = ipaddr,
|
|
-- commutator = >=,
|
|
-- negator = >=,
|
|
procedure = ipaddr_lt
|
|
);
|
|
|
|
create operator = (
|
|
leftarg = ipaddr,
|
|
rightarg = ipaddr,
|
|
commutator = =,
|
|
-- negator = <>,
|
|
procedure = ipaddr_eq
|
|
);
|
|
|
|
create operator >= (
|
|
leftarg = ipaddr,
|
|
rightarg = ipaddr,
|
|
commutator = <,
|
|
negator = <,
|
|
procedure = ipaddr_ge
|
|
);
|
|
|
|
create operator > (
|
|
leftarg = ipaddr,
|
|
rightarg = ipaddr,
|
|
commutator = <=,
|
|
negator = <=,
|
|
procedure = ipaddr_gt
|
|
);
|
|
|
|
create operator <> (
|
|
leftarg = ipaddr,
|
|
rightarg = ipaddr,
|
|
commutator = <>,
|
|
negator = =,
|
|
procedure = ipaddr_ne
|
|
);
|
|
|
|
create operator ~~ (
|
|
leftarg = ipaddr,
|
|
rightarg = ipaddr,
|
|
commutator = ~~,
|
|
procedure = ipaddr_like
|
|
);
|
|
|
|
--
|
|
-- eof
|
|
--
|