--
-- PostgreSQL database dump
--
SET statement_timeout = 0;
SET client_encoding = 'UTF8';
SET standard_conforming_strings = off;
SET check_function_bodies = false;
SET client_min_messages = warning;
SET escape_string_warning = off;
SET search_path = public, pg_catalog;
--
-- Name: establishmentmeans_dwc; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE establishmentmeans_dwc AS ENUM (
'cultivated',
'wild',
'native',
'exotic',
'invasive',
'escaped from captivity'
);
--
-- Name: TYPE establishmentmeans_dwc; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TYPE establishmentmeans_dwc IS 'See http://rs.tdwg.org/dwc/terms/#establishmentMeans';
--
-- Name: growthform; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE growthform AS ENUM (
'tree',
'shrub',
'liana',
'vine',
'herb',
'hemiepiphyte',
'epiphyte',
'grass',
'forb',
'moss',
'lichen',
'fungus',
'floating aquatic',
'submerged aquatic'
);
--
-- Name: occurrencestatus_dwc; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE occurrencestatus_dwc AS ENUM (
'present',
'absent',
'common',
'irregular',
'rare',
'doubtful'
);
--
-- Name: placerank; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE placerank AS ENUM (
'continent',
'country',
'stateProvince',
'county',
'municipality',
'village',
'site',
'territory',
'region',
'waterBody',
'island',
'islandGroup'
);
--
-- Name: TYPE placerank; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TYPE placerank IS 'county = parish, canton
municipality = city
';
--
-- Name: rankedplacename; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE rankedplacename AS (
rank placerank,
verbatimrank text,
placename text
);
--
-- Name: taxonrank; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE taxonrank AS ENUM (
'unknown',
'suprageneric',
'domain',
'superkingdom',
'kingdom',
'subkingdom',
'infrakingdom',
'superphylum',
'phylum',
'subphylum',
'infraphylum',
'superclass',
'class',
'subclass',
'infraclass',
'superorder',
'order',
'suborder',
'infraorder',
'family group',
'superfamily',
'family',
'subfamily',
'infrafamily',
'family subdivision',
'supertribe',
'tribe',
'subtribe',
'infratribe',
'genus group',
'genus',
'subgenus',
'infragenus',
'genus subdivision',
'section',
'subsection',
'series',
'subseries',
'infrageneric',
'species aggregate',
'species group',
'species',
'subspecies',
'subspecific aggregate',
'below subspecies',
'infraspecies',
'biovariety',
'pathovariety',
'variety',
'subvariety',
'subsubvariety',
'forma',
'subforma',
'subsubforma',
'special forma',
'infraspecific',
'candidate',
'cultivated plants',
'cultivar',
'convar',
'grex',
'cultivar group',
'graft-chimaera',
'denomination class'
);
--
-- Name: TYPE taxonrank; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TYPE taxonrank IS 'From ';
--
-- Name: rankedtaxonname; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE rankedtaxonname AS (
rank taxonrank,
verbatimrank text,
taxonname text
);
--
-- Name: role; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE role AS ENUM (
'unknown',
'collector',
'identifier',
'computer',
'contributor'
);
--
-- Name: taxonclass; Type: TYPE; Schema: public; Owner: -
--
CREATE TYPE taxonclass AS ENUM (
'tree',
'shrub',
'liana',
'vine',
'herb',
'hemiepiphyte',
'epiphyte',
'grass',
'forb',
'moss',
'lichen',
'fungus',
'floating aquatic',
'submerged aquatic',
'cultivated',
'wild',
'native',
'exotic',
'invasive',
'escaped from captivity',
'dominant',
'vascular',
'woody'
);
--
-- Name: TYPE taxonclass; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TYPE taxonclass IS '= growthform + establishmentmeans_dwc + some others';
--
-- Name: _fraction_to_percent(double precision); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION _fraction_to_percent(value double precision) RETURNS double precision
LANGUAGE sql IMMUTABLE STRICT
AS $_$
SELECT $1*100.
$_$;
--
-- Name: _taxonconcept_set_matched_concept_id(integer, integer, double precision); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION _taxonconcept_set_matched_concept_id(taxonconcept_id integer, matched_concept_id integer, matched_concept_fit_fraction double precision DEFAULT NULL::double precision) RETURNS integer
LANGUAGE sql
AS $_$
UPDATE taxonconcept SET
matched_concept_id = $2
, matched_concept_fit_fraction = $3
WHERE taxonconcept_id = $1
RETURNING taxonconcept_id
$_$;
--
-- Name: _taxonconcept_set_parent_id(integer, integer); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION _taxonconcept_set_parent_id(taxonconcept_id integer, parent_id integer) RETURNS integer
LANGUAGE sql
AS $_$
UPDATE taxonconcept SET parent_id = $2 WHERE taxonconcept_id = $1
RETURNING taxonconcept_id
$_$;
--
-- Name: make_analytical_db(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION make_analytical_db() RETURNS void
LANGUAGE sql
AS $$CREATE TABLE analytical_db AS SELECT * FROM analytical_db_view$$;
--
-- Name: party_creator_id_self_ref(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION party_creator_id_self_ref() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
IF new.party_id IS NULL THEN -- prepopulate party_id
new.party_id = nextval('party_party_id_seq'::regclass);
END IF;
IF new.creator_id = 0 THEN -- make self-reference
new.creator_id = new.party_id;
END IF;
RETURN new;
END;
$$;
--
-- Name: place_update_ancestors(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION place_update_ancestors() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
-- Delete existing ancestors
DELETE FROM place_ancestor WHERE place_id = new.place_id;
IF new.parent_id IS NOT NULL THEN
-- Copy parent's ancestors to this node's ancestors
INSERT
INTO place_ancestor
(place_id, ancestor_id)
SELECT
new.place_id, ancestor_id
FROM place_ancestor
WHERE place_id = new.parent_id
;
END IF;
-- Add "ancestor" for this node
/* This is useful for queries, because you don't have to separately test if
the leaf node is the one you're looking for, in addition to that leaf node's
ancestors. */
INSERT
INTO place_ancestor
(place_id, ancestor_id)
VALUES (new.place_id, new.place_id)
;
-- Tell immediate children to update their ancestors lists, which will
-- recursively tell all descendants
UPDATE place
SET place_id = place_id -- need at least one SET statement
-- Add COALESCE() to enable using place_unique index for lookup
WHERE COALESCE(parent_id, 2147483647) = new.place_id
AND place_id != new.place_id -- avoid infinite recursion
;
/* Note: We don't need an ON DELETE trigger to update the descendants'
ancestors when a node is deleted, because the place.place_parent_id
foreign key is set to ON DELETE CASCADE, which just removes all the
descendants anyway. */
RETURN new;
END;
$$;
--
-- Name: placepath_matched_placepath_id_self_ref(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION placepath_matched_placepath_id_self_ref() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
IF new.placepath_id IS NULL THEN -- prepopulate placepath_id
new.placepath_id = nextval('placepath_placepath_id_seq'::regclass);
END IF;
IF new.matched_placepath_id = 0 THEN -- make self-reference
new.matched_placepath_id = new.placepath_id;
END IF;
RETURN new;
END;
$$;
--
-- Name: plantobservation_aggregateoccurrence_count_1(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION plantobservation_aggregateoccurrence_count_1() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
UPDATE aggregateoccurrence
SET count = GREATEST(COALESCE(count, 0), 1) -- at least 1
WHERE aggregateoccurrence_id = new.aggregateoccurrence_id
;
RETURN new;
END;
$$;
--
-- Name: taxonconcept_0_matched_concept_id_self_ref(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION taxonconcept_0_matched_concept_id_self_ref() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
IF new.taxonconcept_id IS NULL THEN -- prepopulate taxonconcept_id
new.taxonconcept_id = nextval('taxonconcept_taxonconcept_id_seq'::regclass);
END IF;
IF new.matched_concept_id = 0 THEN -- make self-reference
new.matched_concept_id = new.taxonconcept_id;
END IF;
RETURN new;
END;
$$;
--
-- Name: taxonconcept_1_matched_concept_min_fit(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION taxonconcept_1_matched_concept_min_fit() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
IF new.matched_concept_id IS NOT NULL
AND new.matched_concept_fit_fraction < 0.8 THEN -- insufficient match
new.matched_concept_id = NULL;
new.matched_concept_fit_fraction = NULL;
END IF;
RETURN new;
END;
$$;
--
-- Name: taxonconcept_2_propagate_accepted_concept_id(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION taxonconcept_2_propagate_accepted_concept_id() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
IF new.matched_concept_id IS NOT NULL THEN
IF new.matched_concept_id = new.taxonconcept_id THEN -- self-reference
new.accepted_concept_id = new.taxonconcept_id;-- make self-reference
ELSE -- propagate from matched concept
new.accepted_concept_id = (
SELECT accepted_concept_id
FROM taxonconcept
WHERE taxonconcept_id = new.matched_concept_id
);
END IF;
-- Update accepted_concept_id on concepts that resolve to this concept
UPDATE taxonconcept
SET accepted_concept_id = new.accepted_concept_id
WHERE matched_concept_id = new.taxonconcept_id
AND taxonconcept_id != new.taxonconcept_id -- avoid infinite recursion
;
END IF;
RETURN new;
END;
$$;
--
-- Name: taxonconcept_3_parent_id_avoid_self_ref(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION taxonconcept_3_parent_id_avoid_self_ref() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
new.parent_id = nullif(new.parent_id, new.taxonconcept_id);
RETURN new;
END;
$$;
SET default_tablespace = '';
SET default_with_oids = false;
--
-- Name: taxonconcept; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxonconcept (
taxonconcept_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
creationdate date,
accepted_concept_id integer,
matched_concept_id integer,
matched_concept_fit_fraction double precision,
parent_id integer,
taxonname text,
rank taxonrank,
verbatimrank text,
identifyingtaxonomicname text,
taxonomicname text,
author text,
taxonomicnamewithauthor text,
family text,
genus text,
species text,
description text,
accessioncode text,
CONSTRAINT taxonconcept_matched_concept_fit_fraction_range CHECK (((matched_concept_fit_fraction >= (0)::double precision) AND (matched_concept_fit_fraction <= (1)::double precision))),
CONSTRAINT taxonconcept_required_key CHECK (((((((sourceaccessioncode IS NOT NULL) OR (taxonname IS NOT NULL)) OR (identifyingtaxonomicname IS NOT NULL)) OR (taxonomicname IS NOT NULL)) OR (taxonomicnamewithauthor IS NOT NULL)) OR ((parent_id IS NOT NULL) AND ((creationdate IS NOT NULL) OR (author IS NOT NULL)))))
);
--
-- Name: TABLE taxonconcept; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE taxonconcept IS 'A taxon concept defined by an entity. Can be at any level in the taxonomic hierarchy. Can be either verbatim or accepted.
"A taxon (plural: taxa) is a group of one (or more) populations of organism(s), which a taxonomist adjudges to be a unit" (http://en.wikipedia.org/wiki/Taxon)
Note that taxonname stores only one rank (e.g. family) of the full taxonomic name. The higher-level ranks are stored in the taxon concept''s chain of parent_id ancestors.
To include a taxon name at a rank with no explicit column, create a parent taxonconcept for it and point to it using parent_id. To include multiple such names, chain the taxonconcepts together using parent_id. Note that lower-level taxa should point to higher-level taxa.
Equivalent to VegBank''s plantConcept and plantName tables, plus plantParent_ID and plantLevel from plantStatus.';
--
-- Name: COLUMN taxonconcept.creator_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.creator_id IS 'The entity that created the taxon concept.';
--
-- Name: COLUMN taxonconcept.sourceaccessioncode; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.sourceaccessioncode IS 'The datasource''s identifier for the taxonconcept.';
--
-- Name: COLUMN taxonconcept.creationdate; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.creationdate IS 'The date the taxonconcept was created or defined. For a taxonconcept applied in a taxondetermination, this is the date the determination was made.';
--
-- Name: COLUMN taxonconcept.accepted_concept_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.accepted_concept_id IS 'The accepted synonym of the taxonconcept.';
--
-- Name: COLUMN taxonconcept.matched_concept_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.matched_concept_id IS 'The taxonconcept containing the closest match to this taxonconcept. taxonconcepts should be linked in a four-level hierarchy of datasource concept -> parsed concept -> matched concept -> accepted concept. A previously-accepted name''s concept should be further linked to the synonym that has replaced it.
To indicate a synonym between taxonconcepts of different sources, choose one taxonconcept to be authoritative and point the other taxonconcept to it using this field.
An accepted name should point to itself in this field. This will happen automatically by setting it to the special value 0.';
--
-- Name: COLUMN taxonconcept.matched_concept_fit_fraction; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.matched_concept_fit_fraction IS 'The closeness of fit of the matched_concept.';
--
-- Name: COLUMN taxonconcept.parent_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.parent_id IS 'The parent taxonconcept. Note that while a taxon *name* may have multiple parents, a taxon *concept* has only one, based on the creator''s opinion of where that taxonconcept goes in the taxonomic hierarchy.';
--
-- Name: COLUMN taxonconcept.taxonname; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.taxonname IS 'The name of the taxon within its parent taxon. This is the lowest-rank portion of this taxonconcept''s full taxonomic name, if it has one.
The morphospecies suffix goes in this field.';
--
-- Name: COLUMN taxonconcept.rank; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.rank IS 'The taxonconcept''s level in the taxonomic hierarchy, standardized to a closed list. Even if you specify a custom verbatimrank, you should also specify a closest-match rank from the taxonrank closed list.';
--
-- Name: COLUMN taxonconcept.verbatimrank; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.verbatimrank IS 'The taxonconcept''s verbatim level in the taxonomic hierarchy. Does not need to be in the taxonrank closed list.';
--
-- Name: COLUMN taxonconcept.identifyingtaxonomicname; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.identifyingtaxonomicname IS 'The taxonomic name that uniquely identifies this taxonconcept. If set, the other fields will not be used in duplicate elimination.';
--
-- Name: COLUMN taxonconcept.taxonomicname; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.taxonomicname IS 'The concatenated taxonomic name which uniquely identifies this taxon. Does not include the author of the name.
Equivalent to Darwin Core''s scientificName.';
--
-- Name: COLUMN taxonconcept.author; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.author IS 'The author of the taxonomic name.
Equivalent to Darwin Core''s scientificNameAuthorship.';
--
-- Name: COLUMN taxonconcept.taxonomicnamewithauthor; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.taxonomicnamewithauthor IS 'The concatenated taxonomic name which uniquely identifies this taxon, plus the author of that name.
Equivalent to Darwin Core''s scientificName + scientificNameAuthorship.
Equivalent to "Name sec. x".';
--
-- Name: COLUMN taxonconcept.family; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.family IS 'The family of the taxonomic name. This is a cached field for easy querying; the identifying version of this field is stored in the chain of parent_id ancestors.';
--
-- Name: COLUMN taxonconcept.genus; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.genus IS 'The genus portion of the taxonomic name. This is a cached field for easy querying; the identifying version of this field is stored in the chain of parent_id ancestors.';
--
-- Name: COLUMN taxonconcept.species; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonconcept.species IS 'The species portion of the taxonomic name. This is a cached field for easy querying; the identifying version of this field is stored in the chain of parent_id ancestors.';
--
-- Name: taxonconcept_update_ancestors(taxonconcept, integer); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION taxonconcept_update_ancestors(new taxonconcept, old_parent_id integer DEFAULT NULL::integer) RETURNS void
LANGUAGE plpgsql
AS $$
DECLARE
-- Use matched_concept_id's ancestors instead if available
parent_id_ taxonconcept.taxonconcept_id%TYPE := COALESCE(
NULLIF(new.matched_concept_id, new.taxonconcept_id), new.parent_id);
BEGIN
IF parent_id_ IS DISTINCT FROM old_parent_id THEN
DECLARE
-- These include the parent itself
old_ancestors integer[] := (
SELECT array_agg(ancestor_id) FROM taxonconcept_ancestor
WHERE taxonconcept_id = old_parent_id
);
new_ancestors integer[] := (
SELECT array_agg(ancestor_id) FROM taxonconcept_ancestor
WHERE taxonconcept_id = parent_id_
);
descendant_id integer;
BEGIN
FOR descendant_id IN -- also includes self
SELECT taxonconcept_id
FROM taxonconcept_ancestor
WHERE ancestor_id = new.taxonconcept_id
LOOP
-- Delete old parent's ancestors
DELETE FROM taxonconcept_ancestor
WHERE taxonconcept_id = descendant_id
AND ancestor_id = ANY (old_ancestors)
;
-- Add new parent's ancestors
INSERT INTO taxonconcept_ancestor
(taxonconcept_id, ancestor_id)
SELECT descendant_id, unnest(new_ancestors)
;
END LOOP;
END;
END IF;
/* Note: We don't need an ON DELETE trigger to update the descendants'
ancestors when a node is deleted, because the
taxonconcept_ancestor.ancestor_id foreign key is ON DELETE CASCADE. */
END;
$$;
--
-- Name: taxonconcept_update_ancestors_on_insert(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION taxonconcept_update_ancestors_on_insert() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
/* Add "ancestor" for this node. This is useful for queries, because you
don't have to separately test if the leaf node is the one you're looking
for, in addition to that leaf node's ancestors. */
INSERT
INTO taxonconcept_ancestor
(taxonconcept_id, ancestor_id)
VALUES (new.taxonconcept_id, new.taxonconcept_id)
;
PERFORM taxonconcept_update_ancestors(new);
RETURN new;
END;
$$;
--
-- Name: taxonconcept_update_ancestors_on_update(); Type: FUNCTION; Schema: public; Owner: -
--
CREATE FUNCTION taxonconcept_update_ancestors_on_update() RETURNS trigger
LANGUAGE plpgsql
AS $$
BEGIN
PERFORM taxonconcept_update_ancestors(new, COALESCE(
NULLIF(old.matched_concept_id, old.taxonconcept_id), old.parent_id));
RETURN new;
END;
$$;
--
-- Name: concat(text); Type: AGGREGATE; Schema: public; Owner: -
--
CREATE AGGREGATE concat(text) (
SFUNC = textcat,
STYPE = text,
INITCOND = ''
);
--
-- Name: address; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE address (
address_id integer NOT NULL,
party_id integer NOT NULL,
organization_id integer,
orgposition text,
email text,
deliverypoint text,
city text,
administrativearea text,
postalcode text,
country text,
currentflag boolean,
addressstartdate date
);
--
-- Name: address_address_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE address_address_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: address_address_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE address_address_id_seq OWNED BY address.address_id;
--
-- Name: aggregateoccurrence; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE aggregateoccurrence (
aggregateoccurrence_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
taxonoccurrence_id integer NOT NULL,
collectiondate date,
cover_fraction double precision,
linecover_m double precision,
basalarea_m2 double precision,
biomass_kg_m2 double precision,
inferencearea_m2 double precision,
count integer,
stratum_id integer,
coverindex_id integer,
occurrencestatus_dwc occurrencestatus_dwc DEFAULT 'present'::occurrencestatus_dwc NOT NULL,
method_id integer,
notes text,
accessioncode text
);
--
-- Name: TABLE aggregateoccurrence; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE aggregateoccurrence IS 'Equivalent to VegBank''s taxonimportance table.';
--
-- Name: COLUMN aggregateoccurrence.linecover_m; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN aggregateoccurrence.linecover_m IS 'The distance in m along which this occurrence intercepts a line subplot.';
--
-- Name: COLUMN aggregateoccurrence.occurrencestatus_dwc; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN aggregateoccurrence.occurrencestatus_dwc IS 'The extent to which the taxon is present. See .';
--
-- Name: aggregateoccurrence_aggregateoccurrence_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE aggregateoccurrence_aggregateoccurrence_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: aggregateoccurrence_aggregateoccurrence_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE aggregateoccurrence_aggregateoccurrence_id_seq OWNED BY aggregateoccurrence.aggregateoccurrence_id;
--
-- Name: location; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE location (
location_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
parent_id integer,
authorlocationcode text,
confidentialitystatus integer DEFAULT 0 NOT NULL,
confidentialityreason text,
sublocationxposition_m double precision,
sublocationyposition_m double precision,
authorzone text,
authordatum text,
authorlocation text,
locationnarrative text,
azimuth double precision,
shape text,
area_m2 double precision,
standsize text,
placementmethod text,
permanence boolean,
layoutnarrative text,
elevation_m double precision,
elevationaccuracy_m double precision,
elevationrange_m double precision,
verbatimelevation text,
slopeaspect_deg double precision,
minslopeaspect_deg double precision,
maxslopeaspect_deg double precision,
slopegradient_fraction double precision,
minslopegradient_fraction double precision,
maxslopegradient_fraction double precision,
topoposition text,
landform text,
surficialdeposits text,
rocktype text,
submitter_surname text,
submitter_givenname text,
submitter_email text,
notespublic boolean,
notesmgt boolean,
revisions boolean,
dateentered date DEFAULT now(),
locationrationalenarrative text,
accessioncode text,
CONSTRAINT location_required_key CHECK (((sourceaccessioncode IS NOT NULL) OR (authorlocationcode IS NOT NULL)))
);
--
-- Name: TABLE location; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE location IS 'Equivalent to VegBank''s plot table.';
--
-- Name: locationcoords; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE locationcoords (
locationcoords_id integer NOT NULL,
location_id integer NOT NULL,
latitude_deg double precision,
longitude_deg double precision,
verbatimlatitude text,
verbatimlongitude text,
verbatimcoordinates text,
footprintgeometry_dwc text,
coordsaccuracy_deg double precision,
identifier_id integer,
determinationdate date,
isoriginal boolean DEFAULT false NOT NULL,
iscurrent boolean DEFAULT false NOT NULL,
calculated boolean
);
--
-- Name: COLUMN locationcoords.footprintgeometry_dwc; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN locationcoords.footprintgeometry_dwc IS 'DwC''s footprintWKT field. "A Well-Known Text (WKT) representation of the shape (footprint, geometry) that defines the Location" (http://rs.tdwg.org/dwc/terms/#footprintWKT).';
--
-- Name: COLUMN locationcoords.coordsaccuracy_deg; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN locationcoords.coordsaccuracy_deg IS 'Accuracy of latitude/longitude or footprint geometry, in meters. This should generally be at least 1 m, which is the accuracy of the best GPSes.';
--
-- Name: locationevent; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE locationevent (
locationevent_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
parent_id integer,
location_id integer,
project_id integer,
authoreventcode text,
previous_id integer,
obsstartdate date,
obsenddate date,
dateaccuracy text,
method_id integer,
temperature_c double precision,
precipitation_m double precision,
autotaxoncover boolean,
originaldata text,
effortlevel text,
floristicquality text,
bryophytequality text,
lichenquality text,
locationeventnarrative text,
landscapenarrative text,
homogeneity text,
phenologicaspect text,
representativeness text,
standmaturity text,
successionalstatus text,
basalarea double precision,
hydrologicregime text,
soilmoistureregime text,
soildrainage text,
watersalinity text,
waterdepth_m double precision,
shoredistance double precision,
soildepth double precision,
organicdepth double precision,
soiltaxon_id integer,
soiltaxonsrc text,
percentbedrock double precision,
percentrockgravel double precision,
percentwood double precision,
percentlitter double precision,
percentbaresoil double precision,
percentwater double precision,
percentother double precision,
nameother text,
treeht double precision,
shrubht double precision,
fieldht double precision,
nonvascularht double precision,
submergedht double precision,
treecover double precision,
shrubcover double precision,
fieldcover double precision,
nonvascularcover double precision,
floatingcover double precision,
submergedcover double precision,
dominantstratum text,
growthform1type text,
growthform2type text,
growthform3type text,
growthform1cover double precision,
growthform2cover double precision,
growthform3cover double precision,
totalcover double precision,
notespublic boolean,
notesmgt boolean,
revisions boolean,
dateentered date DEFAULT now(),
toptaxon1name text,
toptaxon2name text,
toptaxon3name text,
toptaxon4name text,
toptaxon5name text,
numberoftaxa integer,
accessioncode text,
CONSTRAINT locationevent_required_key CHECK (((sourceaccessioncode IS NOT NULL) OR (location_id IS NOT NULL)))
);
--
-- Name: TABLE locationevent; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE locationevent IS 'Equivalent to VegBank''s observation table.';
--
-- Name: locationplace; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE locationplace (
locationplace_id integer NOT NULL,
location_id integer NOT NULL,
placepath_id integer NOT NULL,
identifier_id integer
);
--
-- Name: TABLE locationplace; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE locationplace IS 'Equivalent to VegBank''s place table.';
--
-- Name: method; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE method (
method_id integer NOT NULL,
reference_id integer,
name text NOT NULL,
description text,
diameterheight_m double precision,
mindiameter_m double precision,
maxdiameter_m double precision,
minheight_m double precision,
maxheight_m double precision,
observationtype text,
observationmeasure text,
covermethod_id integer,
samplingfactor double precision DEFAULT 1 NOT NULL,
coverbasis text,
stemsamplemethod text,
shape text,
length_m double precision,
width_m double precision,
radius_m double precision,
area_m2 double precision,
samplearea_m2 double precision,
subplotspacing_m double precision,
subplotmethod_id integer,
pointsperline integer,
accessioncode text
);
--
-- Name: TABLE method; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE method IS 'A method for sampling and aggregating plants. Replaces VegBank''s stratummethod and stratumtype tables.
Important: *All* length- or area-related measurements throughout VegBIEN must be converted to SI base units, e.g. cm -> m, ha -> m^2.**';
--
-- Name: COLUMN method.reference_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.reference_id IS 'Use the reference table (e.g. reference.url) to store a link to the original plain text description.';
--
-- Name: COLUMN method.name; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.name IS 'A short name for the set of methods used. Although there is no existing standard, many names are widely used, and could be useful for finding plots with similar methodology.';
--
-- Name: COLUMN method.description; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.description IS 'Additional metadata helpful for understanding how the data were collected during the observation event.';
--
-- Name: COLUMN method.diameterheight_m; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.diameterheight_m IS 'The height in m at which the diameter is measured. e.g. 1.37 m for breast height (DBH).';
--
-- Name: COLUMN method.mindiameter_m; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.mindiameter_m IS 'Lower diameter limit in m for inclusion of a tree.';
--
-- Name: COLUMN method.maxdiameter_m; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.maxdiameter_m IS 'Upper diameter limit in m for inclusion of a tree.';
--
-- Name: COLUMN method.minheight_m; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.minheight_m IS 'Lower height limit in m for inclusion of a tree.';
--
-- Name: COLUMN method.maxheight_m; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.maxheight_m IS 'Upper height limit in m for inclusion of a tree.';
--
-- Name: COLUMN method.observationtype; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.observationtype IS 'values: aggregate, individual, both';
--
-- Name: COLUMN method.observationmeasure; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.observationmeasure IS 'e.g. count, cover, presence, points-intercepted, distance-intercepted';
--
-- Name: COLUMN method.samplingfactor; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.samplingfactor IS 'Here, we could explicitly say that we are sampling a particular area by a different size representative sample area. Simply divide the number of plants connected to this record by this value to get the extrapolated (or interpolated) number of plants in the area in question. This explicitly notes a subsample or supersample.';
--
-- Name: COLUMN method.coverbasis; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.coverbasis IS 'Were cover values for the total taxon list collected from one contiguous area or dispersed subplots?
entire: Cover based on observation of an entire plot consisting of a single contiguous area of land. subplot-contiguous: Cover based on observation of a single contiguous area of land of less spatial extent than the entire plot.
subplot-regular: Cover based on observation of multiple subplots arranged in a regular pattern within the overall plot.
subplot-random: Cover based on observation of multiple randomly dispersed subplots within the overall plot.
subplot-haphazard: Cover based on observation of multiple subplots haphazardly arranged within the overall plot.
line-intercept: Cover based on length of line touching each species present.
point-intercept: Cover based on number of points for each species present.
';
--
-- Name: COLUMN method.stemsamplemethod; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.stemsamplemethod IS 'The method used to obtain basal area or tree stem data (e.g., full census, point quarter, random pairs, Bitterlich, other).
e.g.:
Full census
Point quarter
Random pairs
Bitterlich
Other
Subsample census';
--
-- Name: COLUMN method.shape; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.shape IS 'e.g. square, rectangle, circle, line, point, other';
--
-- Name: COLUMN method.samplearea_m2; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.samplearea_m2 IS 'The total surface area used for cover estimates and for which a complete species list is provided. If subplots were used, this would be the total area of the subplots without interstitial space.';
--
-- Name: COLUMN method.subplotspacing_m; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.subplotspacing_m IS 'Spacing in m between adjacent subplots, lines (line-intercept data), or points (point-intercept data).';
--
-- Name: COLUMN method.subplotmethod_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.subplotmethod_id IS 'Method to use for each subplot/line/point, which will specify subplot size, line length, etc.';
--
-- Name: COLUMN method.pointsperline; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN method.pointsperline IS 'The number of points sampled on each line subplot for point-intercept data.';
--
-- Name: party; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE party (
party_id integer NOT NULL,
creator_id integer NOT NULL,
salutation text,
givenname text,
middlename text,
surname text,
organizationname text,
currentname_id integer,
contactinstructions text,
email text,
partytype text,
partypublic boolean DEFAULT true,
d_obscount integer,
accessioncode text,
CONSTRAINT party_required_key CHECK (((organizationname IS NOT NULL) OR ((creator_id <> party_id) AND (surname IS NOT NULL))))
);
--
-- Name: COLUMN party.creator_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN party.creator_id IS 'A datasource should point to itself in this field. This will happen automatically by setting it to the special value 0.';
--
-- Name: placepath; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE placepath (
placepath_id integer NOT NULL,
creator_id integer NOT NULL,
placecode text,
matched_placepath_id integer,
place_id integer,
continent text,
country text,
stateprovince text,
county text,
municipality text,
site text,
otherranks rankedplacename[],
CONSTRAINT placepath_required_key CHECK (((((((placecode IS NOT NULL) OR (continent IS NOT NULL)) OR (country IS NOT NULL)) OR (stateprovince IS NOT NULL)) OR (county IS NOT NULL)) OR (otherranks IS NOT NULL)))
);
--
-- Name: TABLE placepath; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE placepath IS 'The full path to a place. Can be either verbatim or accepted. For accepted names, points to the identified place.
To include a placename at a rank with no explicit column, add it to the otherranks array.';
--
-- Name: COLUMN placepath.matched_placepath_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN placepath.matched_placepath_id IS 'The placepath containing the accepted name of this verbatim place path. placepaths should be linked in a two-level hierarchy of datasource name -> accepted name.
A accepted name should point to itself in this field. This will happen automatically by setting it to the special value 0.';
--
-- Name: COLUMN placepath.otherranks; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN placepath.otherranks IS 'Additional ranks which do not have a named column. Put ranks in path order, so that lower-level places come after higher-level places.';
--
-- Name: plantobservation; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE plantobservation (
plantobservation_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
aggregateoccurrence_id integer NOT NULL,
overallheight_m double precision,
overallheightaccuracy_m double precision,
collectionnumber text,
stemcount integer,
plant_id integer,
accessioncode text
);
--
-- Name: TABLE plantobservation; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE plantobservation IS 'Equivalent to VegBank''s stemcount table.';
--
-- Name: COLUMN plantobservation.collectionnumber; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN plantobservation.collectionnumber IS 'The number of the organism within the data collection or event.';
--
-- Name: specimenreplicate; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE specimenreplicate (
specimenreplicate_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
plantobservation_id integer,
institution_id integer,
collectioncode_dwc text,
catalognumber_dwc text,
description text,
specimen_id integer,
accessioncode text,
CONSTRAINT specimenreplicate_required_key CHECK ((((plantobservation_id IS NOT NULL) OR (sourceaccessioncode IS NOT NULL)) OR (catalognumber_dwc IS NOT NULL)))
);
--
-- Name: TABLE specimenreplicate; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE specimenreplicate IS 'A herbarium''s replicate of a specimen. Contains Darwin Core specimen data.';
--
-- Name: COLUMN specimenreplicate.institution_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN specimenreplicate.institution_id IS 'The institution (such as a museum) that the specimenreplicate is from.';
--
-- Name: COLUMN specimenreplicate.collectioncode_dwc; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN specimenreplicate.collectioncode_dwc IS 'The code for the collection that the specimenreplicate is from.';
--
-- Name: taxondetermination; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxondetermination (
taxondetermination_id integer NOT NULL,
taxonoccurrence_id integer NOT NULL,
taxonconcept_id integer NOT NULL,
party_id integer,
role role DEFAULT 'unknown'::role NOT NULL,
determinationtype text,
reference_id integer,
isoriginal boolean DEFAULT false NOT NULL,
iscurrent boolean DEFAULT false NOT NULL,
taxonfit text,
taxonconfidence text,
grouptype text,
notes text,
notespublic boolean,
notesmgt boolean,
revisions boolean,
determinationdate date,
accessioncode text
);
--
-- Name: TABLE taxondetermination; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE taxondetermination IS 'Equivalent to VegBank''s taxoninterpretation table.';
--
-- Name: taxonoccurrence; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxonoccurrence (
taxonoccurrence_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
locationevent_id integer,
authortaxoncode text,
verbatimcollectorname text,
growthform growthform,
iscultivated boolean,
cultivatedbasis text,
isnative boolean,
accessioncode text
);
--
-- Name: TABLE taxonoccurrence; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE taxonoccurrence IS 'Equivalent to VegBank''s taxonobservation table.';
--
-- Name: COLUMN taxonoccurrence.iscultivated; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonoccurrence.iscultivated IS 'cultivated or wild';
--
-- Name: COLUMN taxonoccurrence.cultivatedbasis; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonoccurrence.cultivatedbasis IS 'The reason why a taxonoccurrence was marked as cultivated (or not).';
--
-- Name: COLUMN taxonoccurrence.isnative; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN taxonoccurrence.isnative IS 'native or exotic';
--
-- Name: analytical_db_view; Type: VIEW; Schema: public; Owner: -
--
CREATE VIEW analytical_db_view AS
SELECT datasource.organizationname AS "dataSourceName", accepted_taxonconcept.family, accepted_taxonconcept.genus, accepted_taxonconcept.species, COALESCE(accepted_taxonconcept.taxonomicnamewithauthor, accepted_taxonconcept.taxonomicname) AS taxon, accepted_taxonconcept.author AS "taxonAuthor", accepted_taxonconcept.taxonname AS "taxonMorphospecies", placepath.country, placepath.stateprovince AS "stateProvince", placepath.county AS "countyParish", taxonoccurrence.verbatimcollectorname AS collector, plantobservation.collectionnumber AS "collectionNumber", array_to_string(ARRAY[identifiedby.givenname, identifiedby.middlename, identifiedby.surname], ' '::text) AS "identifiedBy", aggregateoccurrence.collectiondate AS "observationDate", location.authorlocationcode AS "plotCode", functions._m2_to_ha(location.area_m2) AS "plotAreaHa", method.name AS "plotMethod", locationcoords.latitude_deg AS latitude, locationcoords.longitude_deg AS longitude, location.elevation_m, taxonoccurrence.iscultivated AS "isCultivated", taxonoccurrence.cultivatedbasis AS "isCultivatedReason", _fraction_to_percent(aggregateoccurrence.cover_fraction) AS "pctCover" FROM ((((((((((((((location JOIN party datasource ON (((datasource.party_id = location.creator_id) AND (datasource.organizationname IS NOT NULL)))) LEFT JOIN locationcoords USING (location_id)) LEFT JOIN locationplace USING (location_id)) LEFT JOIN placepath USING (placepath_id)) JOIN locationevent USING (location_id)) LEFT JOIN method USING (method_id)) JOIN taxonoccurrence USING (locationevent_id)) JOIN taxondetermination USING (taxonoccurrence_id)) LEFT JOIN party identifiedby ON ((identifiedby.party_id = taxondetermination.party_id))) JOIN taxonconcept datasource_taxonconcept USING (taxonconcept_id)) JOIN taxonconcept accepted_taxonconcept ON ((accepted_taxonconcept.taxonconcept_id = datasource_taxonconcept.accepted_concept_id))) LEFT JOIN aggregateoccurrence USING (taxonoccurrence_id)) LEFT JOIN plantobservation USING (aggregateoccurrence_id)) LEFT JOIN specimenreplicate USING (plantobservation_id));
--
-- Name: classcontributor; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE classcontributor (
classcontributor_id integer NOT NULL,
commclass_id integer NOT NULL,
party_id integer NOT NULL,
role role
);
--
-- Name: classcontributor_classcontributor_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE classcontributor_classcontributor_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: classcontributor_classcontributor_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE classcontributor_classcontributor_id_seq OWNED BY classcontributor.classcontributor_id;
--
-- Name: commclass; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE commclass (
commclass_id integer NOT NULL,
locationevent_id integer NOT NULL,
inspection boolean,
tableanalysis boolean,
multivariateanalysis boolean,
classpublication_id integer,
classnotes text,
commname text,
commcode text,
commframework text,
commlevel text,
classstartdate date,
classstopdate date,
expertsystem text,
accessioncode text
);
--
-- Name: commclass_commclass_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE commclass_commclass_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: commclass_commclass_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE commclass_commclass_id_seq OWNED BY commclass.commclass_id;
--
-- Name: commconcept; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE commconcept (
commconcept_id integer NOT NULL,
commname_id integer NOT NULL,
reference_id integer,
commdescription text,
d_obscount integer,
commname text,
d_currentaccepted boolean,
accessioncode text
);
--
-- Name: commconcept_commconcept_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE commconcept_commconcept_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: commconcept_commconcept_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE commconcept_commconcept_id_seq OWNED BY commconcept.commconcept_id;
--
-- Name: commcorrelation; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE commcorrelation (
commcorrelation_id integer NOT NULL,
commstatus_id integer NOT NULL,
commconcept_id integer NOT NULL,
commconvergence text NOT NULL,
correlationstart date NOT NULL,
correlationstop date
);
--
-- Name: commcorrelation_commcorrelation_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE commcorrelation_commcorrelation_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: commcorrelation_commcorrelation_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE commcorrelation_commcorrelation_id_seq OWNED BY commcorrelation.commcorrelation_id;
--
-- Name: commdetermination; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE commdetermination (
commdetermination_id integer NOT NULL,
commclass_id integer NOT NULL,
commconcept_id integer NOT NULL,
commcode text,
commname text,
classfit text,
classconfidence text,
commauthority_id integer,
notes text,
type boolean,
nomenclaturaltype boolean
);
--
-- Name: commdetermination_commdetermination_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE commdetermination_commdetermination_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: commdetermination_commdetermination_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE commdetermination_commdetermination_id_seq OWNED BY commdetermination.commdetermination_id;
--
-- Name: commlineage; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE commlineage (
commlineage_id integer NOT NULL,
parentcommstatus_id integer NOT NULL,
childcommstatus_id integer NOT NULL
);
--
-- Name: commlineage_commlineage_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE commlineage_commlineage_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: commlineage_commlineage_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE commlineage_commlineage_id_seq OWNED BY commlineage.commlineage_id;
--
-- Name: commname; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE commname (
commname_id integer NOT NULL,
commname text NOT NULL,
reference_id integer,
dateentered date DEFAULT now()
);
--
-- Name: commname_commname_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE commname_commname_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: commname_commname_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE commname_commname_id_seq OWNED BY commname.commname_id;
--
-- Name: commstatus; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE commstatus (
commstatus_id integer NOT NULL,
commconcept_id integer NOT NULL,
reference_id integer,
commconceptstatus text NOT NULL,
commparent_id integer,
commlevel text,
commpartycomments text,
party_id integer NOT NULL,
startdate date NOT NULL,
stopdate date,
accessioncode text
);
--
-- Name: commstatus_commstatus_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE commstatus_commstatus_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: commstatus_commstatus_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE commstatus_commstatus_id_seq OWNED BY commstatus.commstatus_id;
--
-- Name: commusage; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE commusage (
commusage_id integer NOT NULL,
commname_id integer NOT NULL,
commname text,
commconcept_id integer,
commnamestatus text,
classsystem text,
party_id integer,
commstatus_id integer,
usagestart date,
usagestop date
);
--
-- Name: commusage_commusage_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE commusage_commusage_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: commusage_commusage_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE commusage_commusage_id_seq OWNED BY commusage.commusage_id;
--
-- Name: coverindex; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE coverindex (
coverindex_id integer NOT NULL,
covermethod_id integer NOT NULL,
covercode text NOT NULL,
upperlimit double precision,
lowerlimit double precision,
coverpercent double precision NOT NULL,
indexdescription text
);
--
-- Name: coverindex_coverindex_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE coverindex_coverindex_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: coverindex_coverindex_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE coverindex_coverindex_id_seq OWNED BY coverindex.coverindex_id;
--
-- Name: covermethod; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE covermethod (
covermethod_id integer NOT NULL,
reference_id integer,
covertype text NOT NULL,
coverestimationmethod text,
accessioncode text
);
--
-- Name: covermethod_covermethod_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE covermethod_covermethod_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: covermethod_covermethod_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE covermethod_covermethod_id_seq OWNED BY covermethod.covermethod_id;
--
-- Name: dba_preassignacccode_dba_requestnumber_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE dba_preassignacccode_dba_requestnumber_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: definedvalue; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE definedvalue (
definedvalue_id integer NOT NULL,
userdefined_id integer NOT NULL,
tablerecord_id integer NOT NULL,
definedvalue text
);
--
-- Name: definedvalue_definedvalue_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE definedvalue_definedvalue_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: definedvalue_definedvalue_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE definedvalue_definedvalue_id_seq OWNED BY definedvalue.definedvalue_id;
--
-- Name: disturbanceobs; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE disturbanceobs (
disturbanceobs_id integer NOT NULL,
locationevent_id integer NOT NULL,
disturbancetype text NOT NULL,
disturbanceintensity text,
disturbanceage double precision,
disturbanceextent double precision,
disturbancecomment text
);
--
-- Name: disturbanceobs_disturbanceobs_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE disturbanceobs_disturbanceobs_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: disturbanceobs_disturbanceobs_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE disturbanceobs_disturbanceobs_id_seq OWNED BY disturbanceobs.disturbanceobs_id;
--
-- Name: graphic; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE graphic (
graphic_id integer NOT NULL,
locationevent_id integer NOT NULL,
graphicname text,
graphiclocation text,
graphicdescription text,
graphictype text,
graphicdata oid,
graphicdate date,
accessioncode text
);
--
-- Name: graphic_graphic_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE graphic_graphic_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: graphic_graphic_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE graphic_graphic_id_seq OWNED BY graphic.graphic_id;
--
-- Name: location_location_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE location_location_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: location_location_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE location_location_id_seq OWNED BY location.location_id;
--
-- Name: locationcoords_locationcoords_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE locationcoords_locationcoords_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: locationcoords_locationcoords_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE locationcoords_locationcoords_id_seq OWNED BY locationcoords.locationcoords_id;
--
-- Name: locationevent_locationevent_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE locationevent_locationevent_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: locationevent_locationevent_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE locationevent_locationevent_id_seq OWNED BY locationevent.locationevent_id;
--
-- Name: locationeventcontributor; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE locationeventcontributor (
locationeventcontributor_id integer NOT NULL,
locationevent_id integer NOT NULL,
party_id integer NOT NULL,
role role NOT NULL,
contributiondate date
);
--
-- Name: locationeventcontributor_locationeventcontributor_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE locationeventcontributor_locationeventcontributor_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: locationeventcontributor_locationeventcontributor_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE locationeventcontributor_locationeventcontributor_id_seq OWNED BY locationeventcontributor.locationeventcontributor_id;
--
-- Name: locationeventsynonym; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE locationeventsynonym (
locationeventsynonym_id integer NOT NULL,
synonymlocationevent_id integer NOT NULL,
primarylocationevent_id integer NOT NULL,
party_id integer NOT NULL,
role role NOT NULL,
synonymcomment text,
classstartdate date DEFAULT now() NOT NULL,
classstopdate date,
accessioncode text
);
--
-- Name: locationeventsynonym_locationeventsynonym_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE locationeventsynonym_locationeventsynonym_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: locationeventsynonym_locationeventsynonym_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE locationeventsynonym_locationeventsynonym_id_seq OWNED BY locationeventsynonym.locationeventsynonym_id;
--
-- Name: locationplace_locationplace_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE locationplace_locationplace_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: locationplace_locationplace_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE locationplace_locationplace_id_seq OWNED BY locationplace.locationplace_id;
--
-- Name: method_method_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE method_method_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: method_method_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE method_method_id_seq OWNED BY method.method_id;
--
-- Name: methodtaxonclass; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE methodtaxonclass (
methodtaxonclass_id integer NOT NULL,
method_id integer NOT NULL,
taxonconcept_id integer,
included boolean NOT NULL,
submethod_id integer,
taxonclass taxonclass,
CONSTRAINT methodtaxonclass_key_required CHECK (((taxonconcept_id IS NOT NULL) OR (taxonclass IS NOT NULL)))
);
--
-- Name: COLUMN methodtaxonclass.included; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN methodtaxonclass.included IS 'Whether the method includes or excludes this taxon class.';
--
-- Name: COLUMN methodtaxonclass.submethod_id; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN methodtaxonclass.submethod_id IS 'The submethod used to sample just this taxon class, distinct from the main method.';
--
-- Name: methodtaxonclass_methodtaxonclass_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE methodtaxonclass_methodtaxonclass_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: methodtaxonclass_methodtaxonclass_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE methodtaxonclass_methodtaxonclass_id_seq OWNED BY methodtaxonclass.methodtaxonclass_id;
--
-- Name: note; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE note (
note_id integer NOT NULL,
notelink_id integer NOT NULL,
party_id integer NOT NULL,
role role NOT NULL,
notetype text NOT NULL,
notetext text NOT NULL,
notedate date,
accessioncode text
);
--
-- Name: note_note_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE note_note_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: note_note_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE note_note_id_seq OWNED BY note.note_id;
--
-- Name: notelink; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE notelink (
notelink_id integer NOT NULL,
tablename text NOT NULL,
attributename text,
tablerecord integer NOT NULL
);
--
-- Name: notelink_notelink_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE notelink_notelink_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: notelink_notelink_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE notelink_notelink_id_seq OWNED BY notelink.notelink_id;
--
-- Name: party_party_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE party_party_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: party_party_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE party_party_id_seq OWNED BY party.party_id;
--
-- Name: partymember; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE partymember (
partymember_id integer NOT NULL,
parentparty_id integer NOT NULL,
childparty_id integer NOT NULL,
role role,
memberstart date DEFAULT now() NOT NULL,
memberstop date
);
--
-- Name: partymember_partymember_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE partymember_partymember_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: partymember_partymember_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE partymember_partymember_id_seq OWNED BY partymember.partymember_id;
--
-- Name: place; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE place (
place_id integer NOT NULL,
parent_id integer,
rank placerank NOT NULL,
placename text NOT NULL,
placecode text,
placedescription text,
accessioncode text
);
--
-- Name: TABLE place; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE place IS 'An official, named place. Can be at any level in the geographic hierarchy. Note that the placename stores only one rank (e.g. country) of the full path to the place. The higher-level ranks are stored in the place''s chain of parent_id ancestors.
Equivalent to VegBank''s namedPlace table.';
--
-- Name: place_ancestor; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE place_ancestor (
place_id integer NOT NULL,
ancestor_id integer NOT NULL
);
--
-- Name: TABLE place_ancestor; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE place_ancestor IS 'place''s ancestor cross link table.';
--
-- Name: place_place_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE place_place_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: place_place_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE place_place_id_seq OWNED BY place.place_id;
--
-- Name: placecorrelation; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE placecorrelation (
placecorrelation_id integer NOT NULL,
parentplace_id integer NOT NULL,
childplace_id integer NOT NULL,
placeconvergence text NOT NULL
);
--
-- Name: placecorrelation_placecorrelation_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE placecorrelation_placecorrelation_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: placecorrelation_placecorrelation_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE placecorrelation_placecorrelation_id_seq OWNED BY placecorrelation.placecorrelation_id;
--
-- Name: placepath_placepath_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE placepath_placepath_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: placepath_placepath_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE placepath_placepath_id_seq OWNED BY placepath.placepath_id;
--
-- Name: plant; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE plant (
plant_id integer NOT NULL
);
--
-- Name: TABLE plant; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE plant IS 'A physical, tagged plant.';
--
-- Name: plant_plant_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE plant_plant_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: plant_plant_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE plant_plant_id_seq OWNED BY plant.plant_id;
--
-- Name: plantobservation_plantobservation_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE plantobservation_plantobservation_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: plantobservation_plantobservation_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE plantobservation_plantobservation_id_seq OWNED BY plantobservation.plantobservation_id;
--
-- Name: project; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE project (
project_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
projectname text,
projectdescription text,
startdate date,
stopdate date,
d_obscount integer,
d_lastlocationaddeddate date,
accessioncode text,
CONSTRAINT project_required_key CHECK (((sourceaccessioncode IS NOT NULL) OR (projectname IS NOT NULL)))
);
--
-- Name: project_project_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE project_project_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: project_project_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE project_project_id_seq OWNED BY project.project_id;
--
-- Name: projectcontributor; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE projectcontributor (
projectcontributor_id integer NOT NULL,
project_id integer NOT NULL,
party_id integer NOT NULL,
role role,
surname text,
cheatrole text
);
--
-- Name: projectcontributor_projectcontributor_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE projectcontributor_projectcontributor_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: projectcontributor_projectcontributor_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE projectcontributor_projectcontributor_id_seq OWNED BY projectcontributor.projectcontributor_id;
--
-- Name: reference; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE reference (
reference_id integer NOT NULL,
shortname text,
fulltext text,
referencetype text,
title text,
titlesuperior text,
referencejournal_id integer,
volume text,
issue text,
pagerange text,
totalpages integer,
publisher text,
publicationplace text,
isbn text,
edition text,
numberofvolumes integer,
chapternumber integer,
reportnumber integer,
communicationtype text,
degree text,
url text,
doi text,
additionalinfo text,
pubdate date,
accessdate date,
conferencedate date,
accessioncode text
);
--
-- Name: reference_reference_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE reference_reference_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: reference_reference_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE reference_reference_id_seq OWNED BY reference.reference_id;
--
-- Name: referencealtident; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE referencealtident (
referencealtident_id integer NOT NULL,
reference_id integer NOT NULL,
system text,
identifier text NOT NULL
);
--
-- Name: referencealtident_referencealtident_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE referencealtident_referencealtident_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: referencealtident_referencealtident_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE referencealtident_referencealtident_id_seq OWNED BY referencealtident.referencealtident_id;
--
-- Name: referencecontributor; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE referencecontributor (
referencecontributor_id integer NOT NULL,
reference_id integer NOT NULL,
referenceparty_id integer NOT NULL,
roletype text,
"position" integer
);
--
-- Name: referencecontributor_referencecontributor_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE referencecontributor_referencecontributor_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: referencecontributor_referencecontributor_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE referencecontributor_referencecontributor_id_seq OWNED BY referencecontributor.referencecontributor_id;
--
-- Name: referencejournal; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE referencejournal (
referencejournal_id integer NOT NULL,
journal text NOT NULL,
issn text,
abbreviation text,
accessioncode text
);
--
-- Name: referencejournal_referencejournal_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE referencejournal_referencejournal_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: referencejournal_referencejournal_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE referencejournal_referencejournal_id_seq OWNED BY referencejournal.referencejournal_id;
--
-- Name: referenceparty; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE referenceparty (
referenceparty_id integer NOT NULL,
type text,
positionname text,
salutation text,
givenname text,
surname text,
suffix text,
organizationname text,
currentparty_id integer,
accessioncode text
);
--
-- Name: referenceparty_referenceparty_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE referenceparty_referenceparty_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: referenceparty_referenceparty_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE referenceparty_referenceparty_id_seq OWNED BY referenceparty.referenceparty_id;
--
-- Name: revision; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE revision (
revision_id integer NOT NULL,
tablename text NOT NULL,
tableattribute text NOT NULL,
tablerecord integer NOT NULL,
previousvaluetext text NOT NULL,
previousvaluetype text NOT NULL,
previousrevision_id integer,
revisiondate date NOT NULL
);
--
-- Name: revision_revision_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE revision_revision_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: revision_revision_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE revision_revision_id_seq OWNED BY revision.revision_id;
--
-- Name: soilobs; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE soilobs (
soilobs_id integer NOT NULL,
locationevent_id integer NOT NULL,
horizon text DEFAULT 'unknown'::text NOT NULL,
description text,
depthtop_m double precision,
depthbottom_m double precision,
color text,
texture text,
organic_fraction double precision,
sand_fraction double precision,
silt_fraction double precision,
clay_fraction double precision,
coarse_fraction double precision,
ph double precision,
acidity_fraction double precision,
basesaturation_fraction double precision,
cationexchangecapacity_cmol_kg double precision,
conductivity double precision,
carbon_fraction double precision,
phosphorus_fraction double precision,
potassium_fraction double precision,
magnesium_fraction double precision,
nitrogen_fraction double precision,
calcium_fraction double precision,
sodium_fraction double precision
);
--
-- Name: soilobs_soilobs_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE soilobs_soilobs_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: soilobs_soilobs_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE soilobs_soilobs_id_seq OWNED BY soilobs.soilobs_id;
--
-- Name: soiltaxon; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE soiltaxon (
soiltaxon_id integer NOT NULL,
soilcode text,
soilname text,
soillevel integer,
soilparent_id integer,
soilframework text,
accessioncode text
);
--
-- Name: soiltaxon_soiltaxon_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE soiltaxon_soiltaxon_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: soiltaxon_soiltaxon_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE soiltaxon_soiltaxon_id_seq OWNED BY soiltaxon.soiltaxon_id;
--
-- Name: specimen; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE specimen (
specimen_id integer NOT NULL
);
--
-- Name: TABLE specimen; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE specimen IS 'A physical specimen collected from a plant. Used to link replicates of the same specimen together.';
--
-- Name: specimen_specimen_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE specimen_specimen_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: specimen_specimen_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE specimen_specimen_id_seq OWNED BY specimen.specimen_id;
--
-- Name: specimenreplicate_specimenreplicate_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE specimenreplicate_specimenreplicate_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: specimenreplicate_specimenreplicate_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE specimenreplicate_specimenreplicate_id_seq OWNED BY specimenreplicate.specimenreplicate_id;
--
-- Name: stemobservation; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE stemobservation (
stemobservation_id integer NOT NULL,
creator_id integer NOT NULL,
sourceaccessioncode text,
plantobservation_id integer NOT NULL,
authorstemcode text,
tag text,
tags text,
xposition_m double precision,
yposition_m double precision,
diameterbreastheight_m double precision,
basaldiameter_m double precision,
diameteraccuracy_m double precision,
height_m double precision,
heightfirstbranch_m double precision,
heightaccuracy_m double precision,
health text,
age double precision,
accessioncode text
);
--
-- Name: TABLE stemobservation; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE stemobservation IS 'Equivalent to VegBank''s stemlocation table.';
--
-- Name: COLUMN stemobservation.tags; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON COLUMN stemobservation.tags IS 'Stores all tags when multiple tags provided. Older tags go first.';
--
-- Name: stemobservation_stemobservation_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE stemobservation_stemobservation_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: stemobservation_stemobservation_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE stemobservation_stemobservation_id_seq OWNED BY stemobservation.stemobservation_id;
--
-- Name: stratum; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE stratum (
stratum_id integer NOT NULL,
locationevent_id integer NOT NULL,
stratumheight double precision,
stratumbase double precision,
stratumcover double precision,
area double precision,
method_id integer
);
--
-- Name: stratum_stratum_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE stratum_stratum_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: stratum_stratum_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE stratum_stratum_id_seq OWNED BY stratum.stratum_id;
--
-- Name: taxonalt; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxonalt (
taxonalt_id integer NOT NULL,
taxondetermination_id integer NOT NULL,
taxonconcept_id integer NOT NULL,
taxonaltfit text,
taxonaltconfidence text,
taxonaltnotes text
);
--
-- Name: taxonalt_taxonalt_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE taxonalt_taxonalt_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: taxonalt_taxonalt_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE taxonalt_taxonalt_id_seq OWNED BY taxonalt.taxonalt_id;
--
-- Name: taxonconcept_ancestor; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxonconcept_ancestor (
taxonconcept_id integer NOT NULL,
ancestor_id integer NOT NULL
);
--
-- Name: TABLE taxonconcept_ancestor; Type: COMMENT; Schema: public; Owner: -
--
COMMENT ON TABLE taxonconcept_ancestor IS 'Stores the accepted ancestors of a taxonconcept. Auto-populated, so should not be manually modified.';
--
-- Name: taxonconcept_taxonconcept_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE taxonconcept_taxonconcept_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: taxonconcept_taxonconcept_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE taxonconcept_taxonconcept_id_seq OWNED BY taxonconcept.taxonconcept_id;
--
-- Name: taxoncorrelation; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxoncorrelation (
taxoncorrelation_id integer NOT NULL,
taxonstatus_id integer NOT NULL,
taxonconcept_id integer NOT NULL,
plantconvergence text NOT NULL,
correlationstart date NOT NULL,
correlationstop date
);
--
-- Name: taxoncorrelation_taxoncorrelation_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE taxoncorrelation_taxoncorrelation_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: taxoncorrelation_taxoncorrelation_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE taxoncorrelation_taxoncorrelation_id_seq OWNED BY taxoncorrelation.taxoncorrelation_id;
--
-- Name: taxondetermination_taxondetermination_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE taxondetermination_taxondetermination_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: taxondetermination_taxondetermination_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE taxondetermination_taxondetermination_id_seq OWNED BY taxondetermination.taxondetermination_id;
--
-- Name: taxonlineage; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxonlineage (
taxonlineage_id integer NOT NULL,
childtaxonstatus_id integer NOT NULL,
parenttaxonstatus_id integer NOT NULL
);
--
-- Name: taxonlineage_taxonlineage_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE taxonlineage_taxonlineage_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: taxonlineage_taxonlineage_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE taxonlineage_taxonlineage_id_seq OWNED BY taxonlineage.taxonlineage_id;
--
-- Name: taxonoccurrence_taxonoccurrence_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE taxonoccurrence_taxonoccurrence_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: taxonoccurrence_taxonoccurrence_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE taxonoccurrence_taxonoccurrence_id_seq OWNED BY taxonoccurrence.taxonoccurrence_id;
--
-- Name: taxonstatus; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxonstatus (
taxonstatus_id integer NOT NULL,
taxonconcept_id integer NOT NULL,
party_id integer,
taxonconceptstatus text DEFAULT 'undetermined'::text NOT NULL,
reference_id integer,
plantpartycomments text,
startdate date,
stopdate date,
accessioncode text
);
--
-- Name: taxonstatus_taxonstatus_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE taxonstatus_taxonstatus_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: taxonstatus_taxonstatus_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE taxonstatus_taxonstatus_id_seq OWNED BY taxonstatus.taxonstatus_id;
--
-- Name: taxonusage; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE taxonusage (
taxonusage_id integer NOT NULL,
taxonconcept_id integer NOT NULL,
taxonstatus text,
taxon text,
classsystem text,
acceptedsynonym text,
party_id integer,
taxonstatus_id integer,
usagestart date,
usagestop date
);
--
-- Name: taxonusage_taxonusage_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE taxonusage_taxonusage_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: taxonusage_taxonusage_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE taxonusage_taxonusage_id_seq OWNED BY taxonusage.taxonusage_id;
--
-- Name: telephone; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE telephone (
telephone_id integer NOT NULL,
party_id integer NOT NULL,
phonenumber text NOT NULL,
phonetype text NOT NULL
);
--
-- Name: telephone_telephone_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE telephone_telephone_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: telephone_telephone_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE telephone_telephone_id_seq OWNED BY telephone.telephone_id;
--
-- Name: trait; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE trait (
trait_id integer NOT NULL,
stemobservation_id integer NOT NULL,
type text NOT NULL,
value text
);
--
-- Name: trait_trait_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE trait_trait_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: trait_trait_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE trait_trait_id_seq OWNED BY trait.trait_id;
--
-- Name: userdefined; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE userdefined (
userdefined_id integer NOT NULL,
userdefinedname text NOT NULL,
userdefinedmetadata text,
userdefinedcategory text,
userdefinedtype text DEFAULT 'text'::text NOT NULL,
tablename text NOT NULL,
accessioncode text
);
--
-- Name: userdefined_userdefined_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE userdefined_userdefined_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: userdefined_userdefined_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE userdefined_userdefined_id_seq OWNED BY userdefined.userdefined_id;
--
-- Name: voucher; Type: TABLE; Schema: public; Owner: -; Tablespace:
--
CREATE TABLE voucher (
voucher_id integer NOT NULL,
taxonoccurrence_id integer NOT NULL,
specimenreplicate_id integer NOT NULL
);
--
-- Name: voucher_voucher_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE voucher_voucher_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;
--
-- Name: voucher_voucher_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
--
ALTER SEQUENCE voucher_voucher_id_seq OWNED BY voucher.voucher_id;
--
-- Name: address_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE address ALTER COLUMN address_id SET DEFAULT nextval('address_address_id_seq'::regclass);
--
-- Name: aggregateoccurrence_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE aggregateoccurrence ALTER COLUMN aggregateoccurrence_id SET DEFAULT nextval('aggregateoccurrence_aggregateoccurrence_id_seq'::regclass);
--
-- Name: classcontributor_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE classcontributor ALTER COLUMN classcontributor_id SET DEFAULT nextval('classcontributor_classcontributor_id_seq'::regclass);
--
-- Name: commclass_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE commclass ALTER COLUMN commclass_id SET DEFAULT nextval('commclass_commclass_id_seq'::regclass);
--
-- Name: commconcept_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE commconcept ALTER COLUMN commconcept_id SET DEFAULT nextval('commconcept_commconcept_id_seq'::regclass);
--
-- Name: commcorrelation_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE commcorrelation ALTER COLUMN commcorrelation_id SET DEFAULT nextval('commcorrelation_commcorrelation_id_seq'::regclass);
--
-- Name: commdetermination_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE commdetermination ALTER COLUMN commdetermination_id SET DEFAULT nextval('commdetermination_commdetermination_id_seq'::regclass);
--
-- Name: commlineage_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE commlineage ALTER COLUMN commlineage_id SET DEFAULT nextval('commlineage_commlineage_id_seq'::regclass);
--
-- Name: commname_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE commname ALTER COLUMN commname_id SET DEFAULT nextval('commname_commname_id_seq'::regclass);
--
-- Name: commstatus_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE commstatus ALTER COLUMN commstatus_id SET DEFAULT nextval('commstatus_commstatus_id_seq'::regclass);
--
-- Name: commusage_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE commusage ALTER COLUMN commusage_id SET DEFAULT nextval('commusage_commusage_id_seq'::regclass);
--
-- Name: coverindex_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE coverindex ALTER COLUMN coverindex_id SET DEFAULT nextval('coverindex_coverindex_id_seq'::regclass);
--
-- Name: covermethod_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE covermethod ALTER COLUMN covermethod_id SET DEFAULT nextval('covermethod_covermethod_id_seq'::regclass);
--
-- Name: definedvalue_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE definedvalue ALTER COLUMN definedvalue_id SET DEFAULT nextval('definedvalue_definedvalue_id_seq'::regclass);
--
-- Name: disturbanceobs_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE disturbanceobs ALTER COLUMN disturbanceobs_id SET DEFAULT nextval('disturbanceobs_disturbanceobs_id_seq'::regclass);
--
-- Name: graphic_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE graphic ALTER COLUMN graphic_id SET DEFAULT nextval('graphic_graphic_id_seq'::regclass);
--
-- Name: location_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE location ALTER COLUMN location_id SET DEFAULT nextval('location_location_id_seq'::regclass);
--
-- Name: locationcoords_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE locationcoords ALTER COLUMN locationcoords_id SET DEFAULT nextval('locationcoords_locationcoords_id_seq'::regclass);
--
-- Name: locationevent_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE locationevent ALTER COLUMN locationevent_id SET DEFAULT nextval('locationevent_locationevent_id_seq'::regclass);
--
-- Name: locationeventcontributor_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE locationeventcontributor ALTER COLUMN locationeventcontributor_id SET DEFAULT nextval('locationeventcontributor_locationeventcontributor_id_seq'::regclass);
--
-- Name: locationeventsynonym_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE locationeventsynonym ALTER COLUMN locationeventsynonym_id SET DEFAULT nextval('locationeventsynonym_locationeventsynonym_id_seq'::regclass);
--
-- Name: locationplace_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE locationplace ALTER COLUMN locationplace_id SET DEFAULT nextval('locationplace_locationplace_id_seq'::regclass);
--
-- Name: method_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE method ALTER COLUMN method_id SET DEFAULT nextval('method_method_id_seq'::regclass);
--
-- Name: methodtaxonclass_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE methodtaxonclass ALTER COLUMN methodtaxonclass_id SET DEFAULT nextval('methodtaxonclass_methodtaxonclass_id_seq'::regclass);
--
-- Name: note_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE note ALTER COLUMN note_id SET DEFAULT nextval('note_note_id_seq'::regclass);
--
-- Name: notelink_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE notelink ALTER COLUMN notelink_id SET DEFAULT nextval('notelink_notelink_id_seq'::regclass);
--
-- Name: party_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE party ALTER COLUMN party_id SET DEFAULT nextval('party_party_id_seq'::regclass);
--
-- Name: partymember_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE partymember ALTER COLUMN partymember_id SET DEFAULT nextval('partymember_partymember_id_seq'::regclass);
--
-- Name: place_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE place ALTER COLUMN place_id SET DEFAULT nextval('place_place_id_seq'::regclass);
--
-- Name: placecorrelation_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE placecorrelation ALTER COLUMN placecorrelation_id SET DEFAULT nextval('placecorrelation_placecorrelation_id_seq'::regclass);
--
-- Name: placepath_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE placepath ALTER COLUMN placepath_id SET DEFAULT nextval('placepath_placepath_id_seq'::regclass);
--
-- Name: plant_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE plant ALTER COLUMN plant_id SET DEFAULT nextval('plant_plant_id_seq'::regclass);
--
-- Name: plantobservation_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE plantobservation ALTER COLUMN plantobservation_id SET DEFAULT nextval('plantobservation_plantobservation_id_seq'::regclass);
--
-- Name: project_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE project ALTER COLUMN project_id SET DEFAULT nextval('project_project_id_seq'::regclass);
--
-- Name: projectcontributor_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE projectcontributor ALTER COLUMN projectcontributor_id SET DEFAULT nextval('projectcontributor_projectcontributor_id_seq'::regclass);
--
-- Name: reference_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE reference ALTER COLUMN reference_id SET DEFAULT nextval('reference_reference_id_seq'::regclass);
--
-- Name: referencealtident_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE referencealtident ALTER COLUMN referencealtident_id SET DEFAULT nextval('referencealtident_referencealtident_id_seq'::regclass);
--
-- Name: referencecontributor_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE referencecontributor ALTER COLUMN referencecontributor_id SET DEFAULT nextval('referencecontributor_referencecontributor_id_seq'::regclass);
--
-- Name: referencejournal_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE referencejournal ALTER COLUMN referencejournal_id SET DEFAULT nextval('referencejournal_referencejournal_id_seq'::regclass);
--
-- Name: referenceparty_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE referenceparty ALTER COLUMN referenceparty_id SET DEFAULT nextval('referenceparty_referenceparty_id_seq'::regclass);
--
-- Name: revision_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE revision ALTER COLUMN revision_id SET DEFAULT nextval('revision_revision_id_seq'::regclass);
--
-- Name: soilobs_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE soilobs ALTER COLUMN soilobs_id SET DEFAULT nextval('soilobs_soilobs_id_seq'::regclass);
--
-- Name: soiltaxon_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE soiltaxon ALTER COLUMN soiltaxon_id SET DEFAULT nextval('soiltaxon_soiltaxon_id_seq'::regclass);
--
-- Name: specimen_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE specimen ALTER COLUMN specimen_id SET DEFAULT nextval('specimen_specimen_id_seq'::regclass);
--
-- Name: specimenreplicate_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE specimenreplicate ALTER COLUMN specimenreplicate_id SET DEFAULT nextval('specimenreplicate_specimenreplicate_id_seq'::regclass);
--
-- Name: stemobservation_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE stemobservation ALTER COLUMN stemobservation_id SET DEFAULT nextval('stemobservation_stemobservation_id_seq'::regclass);
--
-- Name: stratum_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE stratum ALTER COLUMN stratum_id SET DEFAULT nextval('stratum_stratum_id_seq'::regclass);
--
-- Name: taxonalt_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE taxonalt ALTER COLUMN taxonalt_id SET DEFAULT nextval('taxonalt_taxonalt_id_seq'::regclass);
--
-- Name: taxonconcept_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE taxonconcept ALTER COLUMN taxonconcept_id SET DEFAULT nextval('taxonconcept_taxonconcept_id_seq'::regclass);
--
-- Name: taxoncorrelation_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE taxoncorrelation ALTER COLUMN taxoncorrelation_id SET DEFAULT nextval('taxoncorrelation_taxoncorrelation_id_seq'::regclass);
--
-- Name: taxondetermination_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE taxondetermination ALTER COLUMN taxondetermination_id SET DEFAULT nextval('taxondetermination_taxondetermination_id_seq'::regclass);
--
-- Name: taxonlineage_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE taxonlineage ALTER COLUMN taxonlineage_id SET DEFAULT nextval('taxonlineage_taxonlineage_id_seq'::regclass);
--
-- Name: taxonoccurrence_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE taxonoccurrence ALTER COLUMN taxonoccurrence_id SET DEFAULT nextval('taxonoccurrence_taxonoccurrence_id_seq'::regclass);
--
-- Name: taxonstatus_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE taxonstatus ALTER COLUMN taxonstatus_id SET DEFAULT nextval('taxonstatus_taxonstatus_id_seq'::regclass);
--
-- Name: taxonusage_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE taxonusage ALTER COLUMN taxonusage_id SET DEFAULT nextval('taxonusage_taxonusage_id_seq'::regclass);
--
-- Name: telephone_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE telephone ALTER COLUMN telephone_id SET DEFAULT nextval('telephone_telephone_id_seq'::regclass);
--
-- Name: trait_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE trait ALTER COLUMN trait_id SET DEFAULT nextval('trait_trait_id_seq'::regclass);
--
-- Name: userdefined_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE userdefined ALTER COLUMN userdefined_id SET DEFAULT nextval('userdefined_userdefined_id_seq'::regclass);
--
-- Name: voucher_id; Type: DEFAULT; Schema: public; Owner: -
--
ALTER TABLE voucher ALTER COLUMN voucher_id SET DEFAULT nextval('voucher_voucher_id_seq'::regclass);
--
-- Name: address_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY address
ADD CONSTRAINT address_pkey PRIMARY KEY (address_id);
--
-- Name: aggregateoccurrence_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY aggregateoccurrence
ADD CONSTRAINT aggregateoccurrence_pkey PRIMARY KEY (aggregateoccurrence_id);
--
-- Name: classcontributor_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY classcontributor
ADD CONSTRAINT classcontributor_pkey PRIMARY KEY (classcontributor_id);
--
-- Name: commclass_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commclass
ADD CONSTRAINT commclass_pkey PRIMARY KEY (commclass_id);
--
-- Name: commconcept_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commconcept
ADD CONSTRAINT commconcept_pkey PRIMARY KEY (commconcept_id);
--
-- Name: commconcept_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commconcept
ADD CONSTRAINT commconcept_unique UNIQUE (commname_id);
--
-- Name: commcorrelation_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commcorrelation
ADD CONSTRAINT commcorrelation_pkey PRIMARY KEY (commcorrelation_id);
--
-- Name: commdetermination_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commdetermination
ADD CONSTRAINT commdetermination_pkey PRIMARY KEY (commdetermination_id);
--
-- Name: commdetermination_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commdetermination
ADD CONSTRAINT commdetermination_unique UNIQUE (commclass_id, commconcept_id);
--
-- Name: commlineage_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commlineage
ADD CONSTRAINT commlineage_pkey PRIMARY KEY (commlineage_id);
--
-- Name: commname_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commname
ADD CONSTRAINT commname_pkey PRIMARY KEY (commname_id);
--
-- Name: commname_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commname
ADD CONSTRAINT commname_unique UNIQUE (commname);
--
-- Name: commstatus_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commstatus
ADD CONSTRAINT commstatus_pkey PRIMARY KEY (commstatus_id);
--
-- Name: commusage_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY commusage
ADD CONSTRAINT commusage_pkey PRIMARY KEY (commusage_id);
--
-- Name: coverindex_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY coverindex
ADD CONSTRAINT coverindex_pkey PRIMARY KEY (coverindex_id);
--
-- Name: covermethod_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY covermethod
ADD CONSTRAINT covermethod_pkey PRIMARY KEY (covermethod_id);
--
-- Name: definedvalue_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY definedvalue
ADD CONSTRAINT definedvalue_pkey PRIMARY KEY (definedvalue_id);
--
-- Name: definedvalue_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY definedvalue
ADD CONSTRAINT definedvalue_unique UNIQUE (userdefined_id, tablerecord_id);
--
-- Name: disturbanceobs_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY disturbanceobs
ADD CONSTRAINT disturbanceobs_pkey PRIMARY KEY (disturbanceobs_id);
--
-- Name: graphic_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY graphic
ADD CONSTRAINT graphic_pkey PRIMARY KEY (graphic_id);
--
-- Name: location_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY location
ADD CONSTRAINT location_pkey PRIMARY KEY (location_id);
--
-- Name: locationcoords_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY locationcoords
ADD CONSTRAINT locationcoords_pkey PRIMARY KEY (locationcoords_id);
--
-- Name: locationevent_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY locationevent
ADD CONSTRAINT locationevent_pkey PRIMARY KEY (locationevent_id);
--
-- Name: locationeventcontributor_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY locationeventcontributor
ADD CONSTRAINT locationeventcontributor_pkey PRIMARY KEY (locationeventcontributor_id);
--
-- Name: locationeventsynonym_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY locationeventsynonym
ADD CONSTRAINT locationeventsynonym_pkey PRIMARY KEY (locationeventsynonym_id);
--
-- Name: locationplace_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY locationplace
ADD CONSTRAINT locationplace_pkey PRIMARY KEY (locationplace_id);
--
-- Name: method_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY method
ADD CONSTRAINT method_pkey PRIMARY KEY (method_id);
--
-- Name: methodtaxonclass_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY methodtaxonclass
ADD CONSTRAINT methodtaxonclass_pkey PRIMARY KEY (methodtaxonclass_id);
--
-- Name: methodtaxonclass_unique_description; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY methodtaxonclass
ADD CONSTRAINT methodtaxonclass_unique_description UNIQUE (method_id, taxonclass);
--
-- Name: methodtaxonclass_unique_taxonconcept_id; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY methodtaxonclass
ADD CONSTRAINT methodtaxonclass_unique_taxonconcept_id UNIQUE (method_id, taxonconcept_id);
--
-- Name: note_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY note
ADD CONSTRAINT note_pkey PRIMARY KEY (note_id);
--
-- Name: notelink_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY notelink
ADD CONSTRAINT notelink_pkey PRIMARY KEY (notelink_id);
--
-- Name: party_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY party
ADD CONSTRAINT party_pkey PRIMARY KEY (party_id);
--
-- Name: partymember_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY partymember
ADD CONSTRAINT partymember_pkey PRIMARY KEY (partymember_id);
--
-- Name: place_ancestor_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY place_ancestor
ADD CONSTRAINT place_ancestor_pkey PRIMARY KEY (place_id, ancestor_id);
--
-- Name: place_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY place
ADD CONSTRAINT place_pkey PRIMARY KEY (place_id);
--
-- Name: placecorrelation_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY placecorrelation
ADD CONSTRAINT placecorrelation_pkey PRIMARY KEY (placecorrelation_id);
--
-- Name: placepath_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY placepath
ADD CONSTRAINT placepath_pkey PRIMARY KEY (placepath_id);
--
-- Name: plant_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY plant
ADD CONSTRAINT plant_pkey PRIMARY KEY (plant_id);
--
-- Name: plantobservation_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY plantobservation
ADD CONSTRAINT plantobservation_pkey PRIMARY KEY (plantobservation_id);
--
-- Name: project_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY project
ADD CONSTRAINT project_pkey PRIMARY KEY (project_id);
--
-- Name: project_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY project
ADD CONSTRAINT project_unique UNIQUE (creator_id, projectname);
--
-- Name: projectcontributor_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY projectcontributor
ADD CONSTRAINT projectcontributor_pkey PRIMARY KEY (projectcontributor_id);
--
-- Name: reference_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY reference
ADD CONSTRAINT reference_pkey PRIMARY KEY (reference_id);
--
-- Name: referencealtident_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY referencealtident
ADD CONSTRAINT referencealtident_pkey PRIMARY KEY (referencealtident_id);
--
-- Name: referencecontributor_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY referencecontributor
ADD CONSTRAINT referencecontributor_pkey PRIMARY KEY (referencecontributor_id);
--
-- Name: referencejournal_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY referencejournal
ADD CONSTRAINT referencejournal_pkey PRIMARY KEY (referencejournal_id);
--
-- Name: referenceparty_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY referenceparty
ADD CONSTRAINT referenceparty_pkey PRIMARY KEY (referenceparty_id);
--
-- Name: revision_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY revision
ADD CONSTRAINT revision_pkey PRIMARY KEY (revision_id);
--
-- Name: soilobs_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY soilobs
ADD CONSTRAINT soilobs_pkey PRIMARY KEY (soilobs_id);
--
-- Name: soilobs_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY soilobs
ADD CONSTRAINT soilobs_unique UNIQUE (locationevent_id);
--
-- Name: soiltaxon_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY soiltaxon
ADD CONSTRAINT soiltaxon_pkey PRIMARY KEY (soiltaxon_id);
--
-- Name: specimen_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY specimen
ADD CONSTRAINT specimen_pkey PRIMARY KEY (specimen_id);
--
-- Name: specimenreplicate_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY specimenreplicate
ADD CONSTRAINT specimenreplicate_pkey PRIMARY KEY (specimenreplicate_id);
--
-- Name: stemobservation_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY stemobservation
ADD CONSTRAINT stemobservation_pkey PRIMARY KEY (stemobservation_id);
--
-- Name: stratum_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY stratum
ADD CONSTRAINT stratum_pkey PRIMARY KEY (stratum_id);
--
-- Name: taxonalt_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxonalt
ADD CONSTRAINT taxonalt_pkey PRIMARY KEY (taxonalt_id);
--
-- Name: taxonconcept_ancestor_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxonconcept_ancestor
ADD CONSTRAINT taxonconcept_ancestor_pkey PRIMARY KEY (taxonconcept_id, ancestor_id);
--
-- Name: taxonconcept_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxonconcept
ADD CONSTRAINT taxonconcept_pkey PRIMARY KEY (taxonconcept_id);
--
-- Name: taxoncorrelation_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxoncorrelation
ADD CONSTRAINT taxoncorrelation_pkey PRIMARY KEY (taxoncorrelation_id);
--
-- Name: taxondetermination_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxondetermination
ADD CONSTRAINT taxondetermination_pkey PRIMARY KEY (taxondetermination_id);
--
-- Name: taxonlineage_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxonlineage
ADD CONSTRAINT taxonlineage_pkey PRIMARY KEY (taxonlineage_id);
--
-- Name: taxonoccurrence_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxonoccurrence
ADD CONSTRAINT taxonoccurrence_pkey PRIMARY KEY (taxonoccurrence_id);
--
-- Name: taxonstatus_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxonstatus
ADD CONSTRAINT taxonstatus_pkey PRIMARY KEY (taxonstatus_id);
--
-- Name: taxonstatus_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxonstatus
ADD CONSTRAINT taxonstatus_unique UNIQUE (taxonconcept_id, party_id);
--
-- Name: taxonusage_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY taxonusage
ADD CONSTRAINT taxonusage_pkey PRIMARY KEY (taxonusage_id);
--
-- Name: telephone_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY telephone
ADD CONSTRAINT telephone_pkey PRIMARY KEY (telephone_id);
--
-- Name: trait_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY trait
ADD CONSTRAINT trait_pkey PRIMARY KEY (trait_id);
--
-- Name: userdefined_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY userdefined
ADD CONSTRAINT userdefined_pkey PRIMARY KEY (userdefined_id);
--
-- Name: userdefined_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY userdefined
ADD CONSTRAINT userdefined_unique UNIQUE (tablename, userdefinedname);
--
-- Name: voucher_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY voucher
ADD CONSTRAINT voucher_pkey PRIMARY KEY (voucher_id);
--
-- Name: voucher_unique; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
--
ALTER TABLE ONLY voucher
ADD CONSTRAINT voucher_unique UNIQUE (taxonoccurrence_id, specimenreplicate_id);
--
-- Name: aggregateoccurrence_taxonoccurrence; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE INDEX aggregateoccurrence_taxonoccurrence ON aggregateoccurrence USING btree (taxonoccurrence_id);
--
-- Name: aggregateoccurrence_taxonoccurrence_1_to_1; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX aggregateoccurrence_taxonoccurrence_1_to_1 ON aggregateoccurrence USING btree (taxonoccurrence_id) WHERE (sourceaccessioncode IS NULL);
--
-- Name: aggregateoccurrence_unique_within_creator; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX aggregateoccurrence_unique_within_creator ON aggregateoccurrence USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: commclass_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX commclass_accessioncode_index ON commclass USING btree (accessioncode);
--
-- Name: commclass_unique; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX commclass_unique ON commclass USING btree (locationevent_id, (COALESCE(classnotes, '\\N'::text)));
--
-- Name: commconcept_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX commconcept_accessioncode_index ON commconcept USING btree (accessioncode);
--
-- Name: commstatus_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX commstatus_accessioncode_index ON commstatus USING btree (accessioncode);
--
-- Name: covermethod_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX covermethod_accessioncode_index ON covermethod USING btree (accessioncode);
--
-- Name: graphic_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX graphic_accessioncode_index ON graphic USING btree (accessioncode);
--
-- Name: location_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX location_accessioncode_index ON location USING btree (accessioncode);
--
-- Name: location_unique_within_creator_by_authorlocationcode; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX location_unique_within_creator_by_authorlocationcode ON location USING btree (creator_id, (COALESCE(authorlocationcode, '\\N'::text))) WHERE (((authorlocationcode IS NOT NULL) AND (parent_id IS NULL)) AND (sourceaccessioncode IS NULL));
--
-- Name: location_unique_within_creator_by_sourceaccessioncode; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX location_unique_within_creator_by_sourceaccessioncode ON location USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: location_unique_within_parent; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX location_unique_within_parent ON location USING btree ((COALESCE(parent_id, 2147483647)), (COALESCE(authorlocationcode, '\\N'::text)), (COALESCE(sublocationxposition_m, 'NaN'::double precision)), (COALESCE(sublocationyposition_m, 'NaN'::double precision))) WHERE ((parent_id IS NOT NULL) AND (sourceaccessioncode IS NULL));
--
-- Name: locationcoords_unique; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationcoords_unique ON locationcoords USING btree (location_id, (COALESCE(identifier_id, 2147483647)));
--
-- Name: locationevent_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationevent_accessioncode_index ON locationevent USING btree (accessioncode);
--
-- Name: locationevent_location; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE INDEX locationevent_location ON locationevent USING btree (location_id);
--
-- Name: locationevent_unique_within_creator; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationevent_unique_within_creator ON locationevent USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: locationevent_unique_within_location; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationevent_unique_within_location ON locationevent USING btree (location_id, (COALESCE(authoreventcode, '\\N'::text)), (COALESCE(obsstartdate, 'infinity'::date))) WHERE ((parent_id IS NULL) AND (sourceaccessioncode IS NULL));
--
-- Name: locationevent_unique_within_parent_by_authoreventcode; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationevent_unique_within_parent_by_authoreventcode ON locationevent USING btree ((COALESCE(parent_id, 2147483647)), (COALESCE(authoreventcode, '\\N'::text))) WHERE ((parent_id IS NOT NULL) AND (authoreventcode IS NOT NULL));
--
-- Name: locationevent_unique_within_parent_by_location; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationevent_unique_within_parent_by_location ON locationevent USING btree ((COALESCE(parent_id, 2147483647)), location_id) WHERE (parent_id IS NOT NULL);
--
-- Name: locationevent_unique_within_project; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationevent_unique_within_project ON locationevent USING btree ((COALESCE(project_id, 2147483647)), (COALESCE(authoreventcode, '\\N'::text)), (COALESCE(obsstartdate, 'infinity'::date))) WHERE ((((parent_id IS NULL) AND (project_id IS NOT NULL)) AND (authoreventcode IS NOT NULL)) AND (obsstartdate IS NOT NULL));
--
-- Name: locationeventsynonym_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationeventsynonym_accessioncode_index ON locationeventsynonym USING btree (accessioncode);
--
-- Name: locationplace_unique; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX locationplace_unique ON locationplace USING btree (location_id, placepath_id, (COALESCE(identifier_id, 2147483647)));
--
-- Name: method_accessioncode; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX method_accessioncode ON method USING btree (accessioncode);
--
-- Name: method_unique; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX method_unique ON method USING btree (name, (COALESCE(description, '\\N'::text)));
--
-- Name: note_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX note_accessioncode_index ON note USING btree (accessioncode);
--
-- Name: party_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX party_accessioncode_index ON party USING btree (accessioncode);
--
-- Name: party_unique_root; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX party_unique_root ON party USING btree ((COALESCE(organizationname, '\\N'::text))) WHERE (creator_id = party_id);
--
-- Name: party_unique_within_creator; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX party_unique_within_creator ON party USING btree (creator_id, (COALESCE(organizationname, '\\N'::text)), (COALESCE(surname, '\\N'::text)), (COALESCE(givenname, '\\N'::text)), (COALESCE(middlename, '\\N'::text)));
--
-- Name: place_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX place_accessioncode_index ON place USING btree (accessioncode);
--
-- Name: place_unique; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX place_unique ON place USING btree ((COALESCE(parent_id, 2147483647)), placename, rank);
--
-- Name: placepath_unique_within_creator_by_code; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX placepath_unique_within_creator_by_code ON placepath USING btree (creator_id, (COALESCE(placecode, '\\N'::text))) WHERE (placecode IS NOT NULL);
--
-- Name: placepath_unique_within_creator_by_name; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX placepath_unique_within_creator_by_name ON placepath USING btree (creator_id, (COALESCE(continent, '\\N'::text)), (COALESCE(country, '\\N'::text)), (COALESCE(stateprovince, '\\N'::text)), (COALESCE(county, '\\N'::text)), (COALESCE(municipality, '\\N'::text)), (COALESCE(site, '\\N'::text)), (COALESCE(otherranks, ARRAY[]::rankedplacename[]))) WHERE (placecode IS NULL);
--
-- Name: plantobservation_aggregateoccurrence_1_to_1; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX plantobservation_aggregateoccurrence_1_to_1 ON plantobservation USING btree (aggregateoccurrence_id);
--
-- Name: plantobservation_unique_within_creator; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX plantobservation_unique_within_creator ON plantobservation USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: project_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX project_accessioncode_index ON project USING btree (accessioncode);
--
-- Name: project_unique_name_date; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX project_unique_name_date ON project USING btree (creator_id, (COALESCE(projectname, '\\N'::text)), (COALESCE(startdate, 'infinity'::date))) WHERE (sourceaccessioncode IS NULL);
--
-- Name: project_unique_within_creator; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX project_unique_within_creator ON project USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: reference_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX reference_accessioncode_index ON reference USING btree (accessioncode);
--
-- Name: referencejournal_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX referencejournal_accessioncode_index ON referencejournal USING btree (accessioncode);
--
-- Name: referenceparty_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX referenceparty_accessioncode_index ON referenceparty USING btree (accessioncode);
--
-- Name: soiltaxon_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX soiltaxon_accessioncode_index ON soiltaxon USING btree (accessioncode);
--
-- Name: specimenreplicate_plantobservation; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE INDEX specimenreplicate_plantobservation ON specimenreplicate USING btree (plantobservation_id);
--
-- Name: specimenreplicate_plantobservation_1_to_1; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX specimenreplicate_plantobservation_1_to_1 ON specimenreplicate USING btree ((COALESCE(plantobservation_id, 2147483647))) WHERE (((plantobservation_id IS NOT NULL) AND (sourceaccessioncode IS NULL)) AND (catalognumber_dwc IS NULL));
--
-- Name: specimenreplicate_unique_catalognumber; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX specimenreplicate_unique_catalognumber ON specimenreplicate USING btree (creator_id, (COALESCE(institution_id, 2147483647)), (COALESCE(collectioncode_dwc, '\\N'::text)), (COALESCE(catalognumber_dwc, '\\N'::text)), (COALESCE(plantobservation_id, 2147483647))) WHERE ((catalognumber_dwc IS NOT NULL) AND (sourceaccessioncode IS NULL));
--
-- Name: specimenreplicate_unique_within_creator; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX specimenreplicate_unique_within_creator ON specimenreplicate USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: stemobservation_plantobservation_1_to_1; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX stemobservation_plantobservation_1_to_1 ON stemobservation USING btree (plantobservation_id) WHERE ((sourceaccessioncode IS NULL) AND (authorstemcode IS NULL));
--
-- Name: stemobservation_unique_within_creator; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX stemobservation_unique_within_creator ON stemobservation USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: stemobservation_unique_within_plantobservation; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX stemobservation_unique_within_plantobservation ON stemobservation USING btree (plantobservation_id, (COALESCE(authorstemcode, '\\N'::text)), (COALESCE(tag, '\\N'::text))) WHERE (sourceaccessioncode IS NULL);
--
-- Name: taxonconcept_0_unique_identifying_name; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxonconcept_0_unique_identifying_name ON taxonconcept USING btree (creator_id, (COALESCE(identifyingtaxonomicname, '\\N'::text))) WHERE (identifyingtaxonomicname IS NOT NULL);
--
-- Name: taxonconcept_1_unique_sourceaccessioncode; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxonconcept_1_unique_sourceaccessioncode ON taxonconcept USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: taxonconcept_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxonconcept_accessioncode_index ON taxonconcept USING btree (accessioncode);
--
-- Name: taxonconcept_ancestor_descendants; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE INDEX taxonconcept_ancestor_descendants ON taxonconcept_ancestor USING btree (ancestor_id, taxonconcept_id);
--
-- Name: taxonconcept_matched_concept_id_idx; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE INDEX taxonconcept_matched_concept_id_idx ON taxonconcept USING btree (matched_concept_id);
--
-- Name: taxonconcept_unique; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxonconcept_unique ON taxonconcept USING btree ((COALESCE(parent_id, 2147483647)), (COALESCE(taxonname, '\\N'::text)), (COALESCE(rank, 'unknown'::taxonrank)), creator_id, (COALESCE(sourceaccessioncode, '\\N'::text)), (COALESCE(creationdate, 'infinity'::date)), (COALESCE(identifyingtaxonomicname, '\\N'::text)), (COALESCE(taxonomicname, '\\N'::text)), (COALESCE(author, '\\N'::text)), (COALESCE(taxonomicnamewithauthor, '\\N'::text)));
--
-- Name: taxondetermination_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxondetermination_accessioncode_index ON taxondetermination USING btree (accessioncode);
--
-- Name: taxondetermination_unique; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxondetermination_unique ON taxondetermination USING btree (taxonoccurrence_id, isoriginal, role, (COALESCE(party_id, 2147483647)), taxonconcept_id);
--
-- Name: taxonoccurrence_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxonoccurrence_accessioncode_index ON taxonoccurrence USING btree (accessioncode);
--
-- Name: taxonoccurrence_locationevent; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE INDEX taxonoccurrence_locationevent ON taxonoccurrence USING btree (locationevent_id);
--
-- Name: taxonoccurrence_unique_within_creator; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxonoccurrence_unique_within_creator ON taxonoccurrence USING btree (creator_id, (COALESCE(sourceaccessioncode, '\\N'::text))) WHERE (sourceaccessioncode IS NOT NULL);
--
-- Name: taxonoccurrence_unique_within_locationevent; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxonoccurrence_unique_within_locationevent ON taxonoccurrence USING btree ((COALESCE(locationevent_id, 2147483647)), (COALESCE(authortaxoncode, '\\N'::text))) WHERE (sourceaccessioncode IS NULL);
--
-- Name: taxonstatus_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX taxonstatus_accessioncode_index ON taxonstatus USING btree (accessioncode);
--
-- Name: userdefined_accessioncode_index; Type: INDEX; Schema: public; Owner: -; Tablespace:
--
CREATE UNIQUE INDEX userdefined_accessioncode_index ON userdefined USING btree (accessioncode);
--
-- Name: party_creator_id_self_ref; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER party_creator_id_self_ref BEFORE INSERT OR UPDATE ON party FOR EACH ROW EXECUTE PROCEDURE party_creator_id_self_ref();
--
-- Name: place_update_ancestors; Type: TRIGGER; Schema: public; Owner: -
--
CREATE CONSTRAINT TRIGGER place_update_ancestors AFTER INSERT OR UPDATE ON place DEFERRABLE INITIALLY DEFERRED FOR EACH ROW EXECUTE PROCEDURE place_update_ancestors();
--
-- Name: placepath_matched_placepath_id_self_ref; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER placepath_matched_placepath_id_self_ref BEFORE INSERT OR UPDATE ON placepath FOR EACH ROW EXECUTE PROCEDURE placepath_matched_placepath_id_self_ref();
--
-- Name: plantobservation_aggregateoccurrence_count_1; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER plantobservation_aggregateoccurrence_count_1 AFTER INSERT OR UPDATE ON plantobservation FOR EACH ROW EXECUTE PROCEDURE plantobservation_aggregateoccurrence_count_1();
--
-- Name: taxonconcept_0_matched_concept_id_self_ref; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER taxonconcept_0_matched_concept_id_self_ref BEFORE INSERT OR UPDATE ON taxonconcept FOR EACH ROW EXECUTE PROCEDURE taxonconcept_0_matched_concept_id_self_ref();
--
-- Name: taxonconcept_1_matched_concept_min_fit; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER taxonconcept_1_matched_concept_min_fit BEFORE INSERT OR UPDATE ON taxonconcept FOR EACH ROW EXECUTE PROCEDURE taxonconcept_1_matched_concept_min_fit();
--
-- Name: taxonconcept_2_propagate_accepted_concept_id; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER taxonconcept_2_propagate_accepted_concept_id BEFORE INSERT OR UPDATE ON taxonconcept FOR EACH ROW EXECUTE PROCEDURE taxonconcept_2_propagate_accepted_concept_id();
--
-- Name: taxonconcept_3_parent_id_avoid_self_ref; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER taxonconcept_3_parent_id_avoid_self_ref BEFORE INSERT OR UPDATE ON taxonconcept FOR EACH ROW EXECUTE PROCEDURE taxonconcept_3_parent_id_avoid_self_ref();
--
-- Name: taxonconcept_update_ancestors_on_insert; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER taxonconcept_update_ancestors_on_insert AFTER INSERT ON taxonconcept FOR EACH ROW EXECUTE PROCEDURE taxonconcept_update_ancestors_on_insert();
--
-- Name: taxonconcept_update_ancestors_on_update; Type: TRIGGER; Schema: public; Owner: -
--
CREATE TRIGGER taxonconcept_update_ancestors_on_update AFTER UPDATE ON taxonconcept FOR EACH ROW EXECUTE PROCEDURE taxonconcept_update_ancestors_on_update();
--
-- Name: address_organization_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY address
ADD CONSTRAINT address_organization_id_fkey FOREIGN KEY (organization_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: address_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY address
ADD CONSTRAINT address_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: aggregateoccurrence_coverindex_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY aggregateoccurrence
ADD CONSTRAINT aggregateoccurrence_coverindex_id_fkey FOREIGN KEY (coverindex_id) REFERENCES coverindex(coverindex_id) ON UPDATE CASCADE ON DELETE SET NULL;
--
-- Name: aggregateoccurrence_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY aggregateoccurrence
ADD CONSTRAINT aggregateoccurrence_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: aggregateoccurrence_method_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY aggregateoccurrence
ADD CONSTRAINT aggregateoccurrence_method_id_fkey FOREIGN KEY (method_id) REFERENCES method(method_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: aggregateoccurrence_stratum_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY aggregateoccurrence
ADD CONSTRAINT aggregateoccurrence_stratum_id_fkey FOREIGN KEY (stratum_id) REFERENCES stratum(stratum_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: aggregateoccurrence_taxonoccurrence_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY aggregateoccurrence
ADD CONSTRAINT aggregateoccurrence_taxonoccurrence_id_fkey FOREIGN KEY (taxonoccurrence_id) REFERENCES taxonoccurrence(taxonoccurrence_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: classcontributor_commclass_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY classcontributor
ADD CONSTRAINT classcontributor_commclass_id_fkey FOREIGN KEY (commclass_id) REFERENCES commclass(commclass_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: classcontributor_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY classcontributor
ADD CONSTRAINT classcontributor_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commclass_classpublication_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commclass
ADD CONSTRAINT commclass_classpublication_id_fkey FOREIGN KEY (classpublication_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commclass_locationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commclass
ADD CONSTRAINT commclass_locationevent_id_fkey FOREIGN KEY (locationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commconcept_commname_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commconcept
ADD CONSTRAINT commconcept_commname_id_fkey FOREIGN KEY (commname_id) REFERENCES commname(commname_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commconcept_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commconcept
ADD CONSTRAINT commconcept_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commcorrelation_commconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commcorrelation
ADD CONSTRAINT commcorrelation_commconcept_id_fkey FOREIGN KEY (commconcept_id) REFERENCES commconcept(commconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commcorrelation_commstatus_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commcorrelation
ADD CONSTRAINT commcorrelation_commstatus_id_fkey FOREIGN KEY (commstatus_id) REFERENCES commstatus(commstatus_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commdetermination_commauthority_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commdetermination
ADD CONSTRAINT commdetermination_commauthority_id_fkey FOREIGN KEY (commauthority_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commdetermination_commclass_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commdetermination
ADD CONSTRAINT commdetermination_commclass_id_fkey FOREIGN KEY (commclass_id) REFERENCES commclass(commclass_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commdetermination_commconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commdetermination
ADD CONSTRAINT commdetermination_commconcept_id_fkey FOREIGN KEY (commconcept_id) REFERENCES commconcept(commconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commlineage_childcommstatus_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commlineage
ADD CONSTRAINT commlineage_childcommstatus_id_fkey FOREIGN KEY (childcommstatus_id) REFERENCES commstatus(commstatus_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commlineage_parentcommstatus_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commlineage
ADD CONSTRAINT commlineage_parentcommstatus_id_fkey FOREIGN KEY (parentcommstatus_id) REFERENCES commstatus(commstatus_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commname_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commname
ADD CONSTRAINT commname_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commstatus_commconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commstatus
ADD CONSTRAINT commstatus_commconcept_id_fkey FOREIGN KEY (commconcept_id) REFERENCES commconcept(commconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commstatus_commparent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commstatus
ADD CONSTRAINT commstatus_commparent_id_fkey FOREIGN KEY (commparent_id) REFERENCES commconcept(commconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commstatus_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commstatus
ADD CONSTRAINT commstatus_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commstatus_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commstatus
ADD CONSTRAINT commstatus_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commusage_commconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commusage
ADD CONSTRAINT commusage_commconcept_id_fkey FOREIGN KEY (commconcept_id) REFERENCES commconcept(commconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commusage_commname_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commusage
ADD CONSTRAINT commusage_commname_id_fkey FOREIGN KEY (commname_id) REFERENCES commname(commname_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commusage_commstatus_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commusage
ADD CONSTRAINT commusage_commstatus_id_fkey FOREIGN KEY (commstatus_id) REFERENCES commstatus(commstatus_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: commusage_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY commusage
ADD CONSTRAINT commusage_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: coverindex_covermethod_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY coverindex
ADD CONSTRAINT coverindex_covermethod_id_fkey FOREIGN KEY (covermethod_id) REFERENCES covermethod(covermethod_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: covermethod_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY covermethod
ADD CONSTRAINT covermethod_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: definedvalue_userdefined_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY definedvalue
ADD CONSTRAINT definedvalue_userdefined_id_fkey FOREIGN KEY (userdefined_id) REFERENCES userdefined(userdefined_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: disturbanceobs_locationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY disturbanceobs
ADD CONSTRAINT disturbanceobs_locationevent_id_fkey FOREIGN KEY (locationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: graphic_locationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY graphic
ADD CONSTRAINT graphic_locationevent_id_fkey FOREIGN KEY (locationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: location_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY location
ADD CONSTRAINT location_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: location_parent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY location
ADD CONSTRAINT location_parent_id_fkey FOREIGN KEY (parent_id) REFERENCES location(location_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationcoords_identifier_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationcoords
ADD CONSTRAINT locationcoords_identifier_id_fkey FOREIGN KEY (identifier_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationcoords_location_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationcoords
ADD CONSTRAINT locationcoords_location_id_fkey FOREIGN KEY (location_id) REFERENCES location(location_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationevent_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationevent
ADD CONSTRAINT locationevent_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationevent_location_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationevent
ADD CONSTRAINT locationevent_location_id_fkey FOREIGN KEY (location_id) REFERENCES location(location_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationevent_method_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationevent
ADD CONSTRAINT locationevent_method_id_fkey FOREIGN KEY (method_id) REFERENCES method(method_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationevent_parent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationevent
ADD CONSTRAINT locationevent_parent_id_fkey FOREIGN KEY (parent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationevent_previous_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationevent
ADD CONSTRAINT locationevent_previous_id_fkey FOREIGN KEY (previous_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationevent_project_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationevent
ADD CONSTRAINT locationevent_project_id_fkey FOREIGN KEY (project_id) REFERENCES project(project_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationevent_soiltaxon_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationevent
ADD CONSTRAINT locationevent_soiltaxon_id_fkey FOREIGN KEY (soiltaxon_id) REFERENCES soiltaxon(soiltaxon_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationeventcontributor_locationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationeventcontributor
ADD CONSTRAINT locationeventcontributor_locationevent_id_fkey FOREIGN KEY (locationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationeventcontributor_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationeventcontributor
ADD CONSTRAINT locationeventcontributor_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationeventsynonym_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationeventsynonym
ADD CONSTRAINT locationeventsynonym_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationeventsynonym_primarylocationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationeventsynonym
ADD CONSTRAINT locationeventsynonym_primarylocationevent_id_fkey FOREIGN KEY (primarylocationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationeventsynonym_synonymlocationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationeventsynonym
ADD CONSTRAINT locationeventsynonym_synonymlocationevent_id_fkey FOREIGN KEY (synonymlocationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationplace_identifier_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationplace
ADD CONSTRAINT locationplace_identifier_id_fkey FOREIGN KEY (identifier_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationplace_location_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationplace
ADD CONSTRAINT locationplace_location_id_fkey FOREIGN KEY (location_id) REFERENCES location(location_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: locationplace_placepath_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY locationplace
ADD CONSTRAINT locationplace_placepath_id_fkey FOREIGN KEY (placepath_id) REFERENCES placepath(placepath_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: method_covermethod_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY method
ADD CONSTRAINT method_covermethod_id_fkey FOREIGN KEY (covermethod_id) REFERENCES covermethod(covermethod_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: method_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY method
ADD CONSTRAINT method_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: method_subplotmethod_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY method
ADD CONSTRAINT method_subplotmethod_id_fkey FOREIGN KEY (subplotmethod_id) REFERENCES method(method_id) ON UPDATE CASCADE ON DELETE SET NULL;
--
-- Name: methodtaxonclass_method_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY methodtaxonclass
ADD CONSTRAINT methodtaxonclass_method_id_fkey FOREIGN KEY (method_id) REFERENCES method(method_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: methodtaxonclass_submethod_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY methodtaxonclass
ADD CONSTRAINT methodtaxonclass_submethod_id_fkey FOREIGN KEY (submethod_id) REFERENCES method(method_id) ON UPDATE CASCADE ON DELETE SET NULL;
--
-- Name: methodtaxonclass_taxonconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY methodtaxonclass
ADD CONSTRAINT methodtaxonclass_taxonconcept_id_fkey FOREIGN KEY (taxonconcept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: note_notelink_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY note
ADD CONSTRAINT note_notelink_id_fkey FOREIGN KEY (notelink_id) REFERENCES notelink(notelink_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: note_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY note
ADD CONSTRAINT note_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: party_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY party
ADD CONSTRAINT party_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: party_currentname_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY party
ADD CONSTRAINT party_currentname_id_fkey FOREIGN KEY (currentname_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: partymember_childparty_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY partymember
ADD CONSTRAINT partymember_childparty_id_fkey FOREIGN KEY (childparty_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: partymember_parentparty_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY partymember
ADD CONSTRAINT partymember_parentparty_id_fkey FOREIGN KEY (parentparty_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: place_ancestor_ancestor_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY place_ancestor
ADD CONSTRAINT place_ancestor_ancestor_id_fkey FOREIGN KEY (ancestor_id) REFERENCES place(place_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: place_ancestor_place_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY place_ancestor
ADD CONSTRAINT place_ancestor_place_id_fkey FOREIGN KEY (place_id) REFERENCES place(place_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: place_parent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY place
ADD CONSTRAINT place_parent_id_fkey FOREIGN KEY (parent_id) REFERENCES place(place_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: placecorrelation_childplace_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY placecorrelation
ADD CONSTRAINT placecorrelation_childplace_id_fkey FOREIGN KEY (childplace_id) REFERENCES place(place_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: placecorrelation_parentplace_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY placecorrelation
ADD CONSTRAINT placecorrelation_parentplace_id_fkey FOREIGN KEY (parentplace_id) REFERENCES place(place_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: placepath_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY placepath
ADD CONSTRAINT placepath_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: placepath_matched_placepath_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY placepath
ADD CONSTRAINT placepath_matched_placepath_id_fkey FOREIGN KEY (matched_placepath_id) REFERENCES placepath(placepath_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: placepath_place_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY placepath
ADD CONSTRAINT placepath_place_id_fkey FOREIGN KEY (place_id) REFERENCES place(place_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: plantobservation_aggregateoccurrence_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY plantobservation
ADD CONSTRAINT plantobservation_aggregateoccurrence_id_fkey FOREIGN KEY (aggregateoccurrence_id) REFERENCES aggregateoccurrence(aggregateoccurrence_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: plantobservation_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY plantobservation
ADD CONSTRAINT plantobservation_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: plantobservation_plant_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY plantobservation
ADD CONSTRAINT plantobservation_plant_id_fkey FOREIGN KEY (plant_id) REFERENCES plant(plant_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: project_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY project
ADD CONSTRAINT project_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: projectcontributor_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY projectcontributor
ADD CONSTRAINT projectcontributor_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: projectcontributor_project_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY projectcontributor
ADD CONSTRAINT projectcontributor_project_id_fkey FOREIGN KEY (project_id) REFERENCES project(project_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: reference_referencejournal_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY reference
ADD CONSTRAINT reference_referencejournal_id_fkey FOREIGN KEY (referencejournal_id) REFERENCES referencejournal(referencejournal_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: referencealtident_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY referencealtident
ADD CONSTRAINT referencealtident_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: referencecontributor_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY referencecontributor
ADD CONSTRAINT referencecontributor_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: referencecontributor_referenceparty_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY referencecontributor
ADD CONSTRAINT referencecontributor_referenceparty_id_fkey FOREIGN KEY (referenceparty_id) REFERENCES referenceparty(referenceparty_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: referenceparty_currentparty_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY referenceparty
ADD CONSTRAINT referenceparty_currentparty_id_fkey FOREIGN KEY (currentparty_id) REFERENCES referenceparty(referenceparty_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: revision_previousrevision_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY revision
ADD CONSTRAINT revision_previousrevision_id_fkey FOREIGN KEY (previousrevision_id) REFERENCES revision(revision_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: soilobs_locationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY soilobs
ADD CONSTRAINT soilobs_locationevent_id_fkey FOREIGN KEY (locationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: soiltaxon_soilparent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY soiltaxon
ADD CONSTRAINT soiltaxon_soilparent_id_fkey FOREIGN KEY (soilparent_id) REFERENCES soiltaxon(soiltaxon_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: specimenreplicate_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY specimenreplicate
ADD CONSTRAINT specimenreplicate_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: specimenreplicate_institution_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY specimenreplicate
ADD CONSTRAINT specimenreplicate_institution_id_fkey FOREIGN KEY (institution_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: specimenreplicate_plantobservation_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY specimenreplicate
ADD CONSTRAINT specimenreplicate_plantobservation_id_fkey FOREIGN KEY (plantobservation_id) REFERENCES plantobservation(plantobservation_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: specimenreplicate_specimen_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY specimenreplicate
ADD CONSTRAINT specimenreplicate_specimen_id_fkey FOREIGN KEY (specimen_id) REFERENCES specimen(specimen_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: stemobservation_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY stemobservation
ADD CONSTRAINT stemobservation_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: stemobservation_plantobservation_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY stemobservation
ADD CONSTRAINT stemobservation_plantobservation_id_fkey FOREIGN KEY (plantobservation_id) REFERENCES plantobservation(plantobservation_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: stratum_locationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY stratum
ADD CONSTRAINT stratum_locationevent_id_fkey FOREIGN KEY (locationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: stratum_method_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY stratum
ADD CONSTRAINT stratum_method_id_fkey FOREIGN KEY (method_id) REFERENCES method(method_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonalt_taxonconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonalt
ADD CONSTRAINT taxonalt_taxonconcept_id_fkey FOREIGN KEY (taxonconcept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonalt_taxondetermination_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonalt
ADD CONSTRAINT taxonalt_taxondetermination_id_fkey FOREIGN KEY (taxondetermination_id) REFERENCES taxondetermination(taxondetermination_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonconcept_accepted_concept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonconcept
ADD CONSTRAINT taxonconcept_accepted_concept_id_fkey FOREIGN KEY (accepted_concept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonconcept_ancestor_ancestor_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonconcept_ancestor
ADD CONSTRAINT taxonconcept_ancestor_ancestor_id_fkey FOREIGN KEY (ancestor_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonconcept_ancestor_taxonconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonconcept_ancestor
ADD CONSTRAINT taxonconcept_ancestor_taxonconcept_id_fkey FOREIGN KEY (taxonconcept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonconcept_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonconcept
ADD CONSTRAINT taxonconcept_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonconcept_matched_concept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonconcept
ADD CONSTRAINT taxonconcept_matched_concept_id_fkey FOREIGN KEY (matched_concept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonconcept_parent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonconcept
ADD CONSTRAINT taxonconcept_parent_id_fkey FOREIGN KEY (parent_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxoncorrelation_taxonconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxoncorrelation
ADD CONSTRAINT taxoncorrelation_taxonconcept_id_fkey FOREIGN KEY (taxonconcept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxoncorrelation_taxonstatus_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxoncorrelation
ADD CONSTRAINT taxoncorrelation_taxonstatus_id_fkey FOREIGN KEY (taxonstatus_id) REFERENCES taxonstatus(taxonstatus_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxondetermination_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxondetermination
ADD CONSTRAINT taxondetermination_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxondetermination_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxondetermination
ADD CONSTRAINT taxondetermination_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxondetermination_taxonconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxondetermination
ADD CONSTRAINT taxondetermination_taxonconcept_id_fkey FOREIGN KEY (taxonconcept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxondetermination_taxonoccurrence_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxondetermination
ADD CONSTRAINT taxondetermination_taxonoccurrence_id_fkey FOREIGN KEY (taxonoccurrence_id) REFERENCES taxonoccurrence(taxonoccurrence_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonlineage_childtaxonstatus_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonlineage
ADD CONSTRAINT taxonlineage_childtaxonstatus_id_fkey FOREIGN KEY (childtaxonstatus_id) REFERENCES taxonstatus(taxonstatus_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonlineage_parenttaxonstatus_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonlineage
ADD CONSTRAINT taxonlineage_parenttaxonstatus_id_fkey FOREIGN KEY (parenttaxonstatus_id) REFERENCES taxonstatus(taxonstatus_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonoccurrence_creator_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonoccurrence
ADD CONSTRAINT taxonoccurrence_creator_id_fkey FOREIGN KEY (creator_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonoccurrence_locationevent_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonoccurrence
ADD CONSTRAINT taxonoccurrence_locationevent_id_fkey FOREIGN KEY (locationevent_id) REFERENCES locationevent(locationevent_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonstatus_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonstatus
ADD CONSTRAINT taxonstatus_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonstatus_reference_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonstatus
ADD CONSTRAINT taxonstatus_reference_id_fkey FOREIGN KEY (reference_id) REFERENCES reference(reference_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonstatus_taxonconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonstatus
ADD CONSTRAINT taxonstatus_taxonconcept_id_fkey FOREIGN KEY (taxonconcept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonusage_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonusage
ADD CONSTRAINT taxonusage_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonusage_taxonconcept_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonusage
ADD CONSTRAINT taxonusage_taxonconcept_id_fkey FOREIGN KEY (taxonconcept_id) REFERENCES taxonconcept(taxonconcept_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: taxonusage_taxonstatus_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY taxonusage
ADD CONSTRAINT taxonusage_taxonstatus_id_fkey FOREIGN KEY (taxonstatus_id) REFERENCES taxonstatus(taxonstatus_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: telephone_party_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY telephone
ADD CONSTRAINT telephone_party_id_fkey FOREIGN KEY (party_id) REFERENCES party(party_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: trait_stemobservation_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY trait
ADD CONSTRAINT trait_stemobservation_id_fkey FOREIGN KEY (stemobservation_id) REFERENCES stemobservation(stemobservation_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: voucher_specimenreplicate_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY voucher
ADD CONSTRAINT voucher_specimenreplicate_id_fkey FOREIGN KEY (specimenreplicate_id) REFERENCES specimenreplicate(specimenreplicate_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- Name: voucher_taxonoccurrence_id_fkey; Type: FK CONSTRAINT; Schema: public; Owner: -
--
ALTER TABLE ONLY voucher
ADD CONSTRAINT voucher_taxonoccurrence_id_fkey FOREIGN KEY (taxonoccurrence_id) REFERENCES taxonoccurrence(taxonoccurrence_id) ON UPDATE CASCADE ON DELETE CASCADE;
--
-- PostgreSQL database dump complete
--