mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-10-01 06:21:15 +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.
89 lines
1.6 KiB
SQL
89 lines
1.6 KiB
SQL
--
|
|
-- PostgreSQL code for MAC addresses.
|
|
--
|
|
|
|
load '/usr/local/pgsql/modules/mac.so';
|
|
|
|
--
|
|
-- Input and output functions and the type itself:
|
|
--
|
|
|
|
create function macaddr_in(opaque)
|
|
returns opaque
|
|
as '/usr/local/pgsql/modules/mac.so'
|
|
language 'c';
|
|
|
|
create function macaddr_out(opaque)
|
|
returns opaque
|
|
as '/usr/local/pgsql/modules/mac.so'
|
|
language 'c';
|
|
|
|
create type macaddr (
|
|
internallength = 8,
|
|
externallength = variable,
|
|
input = macaddr_in,
|
|
output = macaddr_out
|
|
);
|
|
|
|
--
|
|
-- The various boolean tests:
|
|
--
|
|
|
|
create function macaddr_eq(macaddr, macaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/mac.so'
|
|
language 'c';
|
|
|
|
create function macaddr_ne(macaddr, macaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/mac.so'
|
|
language 'c';
|
|
|
|
create function macaddr_like(macaddr, macaddr)
|
|
returns bool
|
|
as '/usr/local/pgsql/modules/mac.so'
|
|
language 'c';
|
|
|
|
--
|
|
-- Now the operators. Note how the "negator = <>" in the
|
|
-- definition of the equivalence operator is commented out.
|
|
-- It gets defined implicitly when "<>" is defined, with
|
|
-- "=" as its negator.
|
|
--
|
|
|
|
create operator = (
|
|
leftarg = macaddr,
|
|
rightarg = macaddr,
|
|
commutator = =,
|
|
-- negator = <>,
|
|
procedure = macaddr_eq
|
|
);
|
|
|
|
create operator <> (
|
|
leftarg = macaddr,
|
|
rightarg = macaddr,
|
|
commutator = <>,
|
|
negator = =,
|
|
procedure = macaddr_ne
|
|
);
|
|
|
|
create operator ~~ (
|
|
leftarg = macaddr,
|
|
rightarg = macaddr,
|
|
commutator = ~~,
|
|
procedure = macaddr_like
|
|
);
|
|
|
|
--
|
|
-- Finally, the special manufacurer matching function:
|
|
--
|
|
|
|
create function macaddr_manuf(macaddr)
|
|
returns text
|
|
as '/usr/local/pgsql/modules/mac.so'
|
|
language 'c';
|
|
|
|
--
|
|
-- eof
|
|
--
|