﻿================================================================================
DOCUMENTO: Schema SQL Completo: EDGV 300 (PostGIS)
================================================================================
DESCRIÇÃO:
Script SQL completo que define o schema do banco de dados PostGIS para o modelo EDGV 3.0 (Especificação Técnica para a Estruturação de Dados Geoespaciais Vetoriais). Contém CREATE TABLE, tipos, domínios, constraints e índices de todas as classes de feições geoespaciais do modelo.

ARQUIVO ORIGINAL: C:\DESENVOLVIMENTO\dados-modelagens\edgv_300\edgv_300.sql
TAMANHO ORIGINAL: 802.5 KB
GERADO EM: 2026-03-17 22:37:46
PROJETO: EDGV - Especificação Técnica para a Estruturação de Dados Geoespaciais Vetoriais
CONTEXTO: Pipeline ETL para conversão de dados geoespaciais entre formatos Shapefile, PostGIS e modelos EDGV
================================================================================

CONTEÚDO DO ARQUIVO:
================================================================================

[ANÁLISE ESTRUTURAL DO SQL]
Total de linhas: 19346
Tabelas (CREATE TABLE): 442
  - public.db_metadata
  - 
  - 
  - 
  - 
  - 
  - 
  - 
  - 
  - 
  ... e mais 432 tabelas
Índices (CREATE INDEX): 295

[CONTEÚDO SQL COMPLETO]

CREATE SCHEMA edgv;
CREATE SCHEMA dominios;

CREATE EXTENSION postgis;
CREATE EXTENSION IF NOT EXISTS "uuid-ossp";
SET search_path TO pg_catalog,public,edgv,dominios;

CREATE TABLE public.db_metadata(
	 edgvversion varchar(50) NOT NULL DEFAULT 'EDGV 3.0',
	 dbimplversion varchar(50) NOT NULL DEFAULT '1.1.6',
	 CONSTRAINT edgvversioncheck CHECK (edgvversion = 'EDGV 3.0')
);
INSERT INTO public.db_metadata (edgvversion, dbimplversion) VALUES ('EDGV 3.0','1.1.6');

CREATE TABLE dominios.aptidao_operacional_atracadouro (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT aptidao_operacional_atracadouro_pk PRIMARY KEY (code)
);

INSERT INTO dominios.aptidao_operacional_atracadouro (code,code_name) VALUES (2,'Transporte de cabotagem (2)');
INSERT INTO dominios.aptidao_operacional_atracadouro (code,code_name) VALUES (3,'Transporte oceânico (3)');
INSERT INTO dominios.aptidao_operacional_atracadouro (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.aptidao_operacional_atracadouro OWNER TO postgres;

CREATE TABLE dominios.tipo_sinal (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_sinal_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_sinal (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_sinal (code,code_name) VALUES (1,'Boia luminosa (1)');
INSERT INTO dominios.tipo_sinal (code,code_name) VALUES (2,'Boia cega (2)');
INSERT INTO dominios.tipo_sinal (code,code_name) VALUES (3,'Boia de amarração (3)');
INSERT INTO dominios.tipo_sinal (code,code_name) VALUES (4,'Farol ou farolete (4)');
INSERT INTO dominios.tipo_sinal (code,code_name) VALUES (5,'Barca farol (5)');
INSERT INTO dominios.tipo_sinal (code,code_name) VALUES (6,'Sinalização de margem (6)');
INSERT INTO dominios.tipo_sinal (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_sinal OWNER TO postgres;

CREATE TABLE dominios.finalidade_cultura (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT finalidade_cultura_pk PRIMARY KEY (code)
);

INSERT INTO dominios.finalidade_cultura (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.finalidade_cultura (code,code_name) VALUES (1,'Exploração econômica (1)');
INSERT INTO dominios.finalidade_cultura (code,code_name) VALUES (2,'Subsistência (2)');
INSERT INTO dominios.finalidade_cultura (code,code_name) VALUES (3,'Conservação ambiental (3)');
INSERT INTO dominios.finalidade_cultura (code,code_name) VALUES (4,'Ornamental (4)');
INSERT INTO dominios.finalidade_cultura (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.finalidade_cultura (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.finalidade_cultura OWNER TO postgres;

CREATE TABLE dominios.tipo_travessia_ped (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_travessia_ped_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_travessia_ped (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_travessia_ped (code,code_name) VALUES (7,'Passagem subterrânea (7)');
INSERT INTO dominios.tipo_travessia_ped (code,code_name) VALUES (8,'Passarela (8)');
INSERT INTO dominios.tipo_travessia_ped (code,code_name) VALUES (9,'Pinguela (9)');
INSERT INTO dominios.tipo_travessia_ped (code,code_name) VALUES (10,'Passarela em área úmida (10)');
INSERT INTO dominios.tipo_travessia_ped (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_travessia_ped OWNER TO postgres;

CREATE TABLE dominios.tipo_quebra_molhe (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_quebra_molhe_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_quebra_molhe (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_quebra_molhe (code,code_name) VALUES (1,'Quebramar (1)');
INSERT INTO dominios.tipo_quebra_molhe (code,code_name) VALUES (2,'Molhe (2)');
INSERT INTO dominios.tipo_quebra_molhe (code,code_name) VALUES (4,'Espigão (4)');
INSERT INTO dominios.tipo_quebra_molhe (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_quebra_molhe OWNER TO postgres;

CREATE TABLE dominios.bitola (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT bitola_pk PRIMARY KEY (code)
);

INSERT INTO dominios.bitola (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.bitola (code,code_name) VALUES (1,'Métrica (1)');
INSERT INTO dominios.bitola (code,code_name) VALUES (2,'Internacional (2)');
INSERT INTO dominios.bitola (code,code_name) VALUES (3,'Larga (3)');
INSERT INTO dominios.bitola (code,code_name) VALUES (4,'Mista métrica internacional (4)');
INSERT INTO dominios.bitola (code,code_name) VALUES (5,'Mista métrica larga (5)');
INSERT INTO dominios.bitola (code,code_name) VALUES (6,'Mista internacional larga (6)');
INSERT INTO dominios.bitola (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.bitola OWNER TO postgres;

CREATE TABLE dominios.forma_extracao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT forma_extracao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.forma_extracao (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.forma_extracao (code,code_name) VALUES (5,'A céu aberto (5)');
INSERT INTO dominios.forma_extracao (code,code_name) VALUES (6,'Subterrânea (6)');
INSERT INTO dominios.forma_extracao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.forma_extracao OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_turist (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_turist_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (9,'Cruzeiro (9)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (10,'Estátua (10)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (11,'Mirante (11)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (12,'Monumento (12)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (13,'Panteão (13)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (14,'Chafariz (14)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (15,'Chaminé (15)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (16,'Escultura (16)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (17,'Obelisco (17)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (18,'Torre (18)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (19,'Administração (19)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_turist (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_turist OWNER TO postgres;

CREATE TABLE dominios.tipo_trecho_duto (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_trecho_duto_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_trecho_duto (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_trecho_duto (code,code_name) VALUES (1,'Duto (1)');
INSERT INTO dominios.tipo_trecho_duto (code,code_name) VALUES (2,'Calha (2)');
INSERT INTO dominios.tipo_trecho_duto (code,code_name) VALUES (3,'Correia transportadora (3)');
INSERT INTO dominios.tipo_trecho_duto (code,code_name) VALUES (4,'Bueiro (4)');
INSERT INTO dominios.tipo_trecho_duto (code,code_name) VALUES (5,'Galeria (5)');
INSERT INTO dominios.tipo_trecho_duto (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_trecho_duto OWNER TO postgres;

CREATE TABLE dominios.tipo_unid_prot_integ (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_unid_prot_integ_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_unid_prot_integ (code,code_name) VALUES (1,'Estação ecológica - ESEC (1)');
INSERT INTO dominios.tipo_unid_prot_integ (code,code_name) VALUES (2,'Parque - PAR (2)');
INSERT INTO dominios.tipo_unid_prot_integ (code,code_name) VALUES (3,'Monumento natural – MONA (3)');
INSERT INTO dominios.tipo_unid_prot_integ (code,code_name) VALUES (4,'Reserva biológica – REBIO (4)');
INSERT INTO dominios.tipo_unid_prot_integ (code,code_name) VALUES (5,'Refúgio da vida silvestre – RVS (5)');
INSERT INTO dominios.tipo_unid_prot_integ (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_unid_prot_integ OWNER TO postgres;

CREATE TABLE dominios.tipo_uso_edif (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_uso_edif_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_uso_edif (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_uso_edif (code,code_name) VALUES (1,'Próprio nacional (1)');
INSERT INTO dominios.tipo_uso_edif (code,code_name) VALUES (2,'Uso da União (2)');
INSERT INTO dominios.tipo_uso_edif (code,code_name) VALUES (5,'Uso do município (5)');
INSERT INTO dominios.tipo_uso_edif (code,code_name) VALUES (6,'Uso da UF (6)');
INSERT INTO dominios.tipo_uso_edif (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_uso_edif (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_uso_edif OWNER TO postgres;

CREATE TABLE dominios.tipo_dep_geral (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_dep_geral_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (1,'Tanque (1)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (2,'Caixa d''água (2)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (3,'Cisterna (3)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (4,'Depósito de lixo (4)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (5,'Aterro sanitário (5)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (6,'Aterro controlado (6)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (8,'Galpão (8)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (9,'Silo (9)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (10,'Composteira (10)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (11,'Depósito frigorífico (11)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (19,'Reservatório (19)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (26,'Barracão industrial (26)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (32,'Armazém (32)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_dep_geral (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_dep_geral OWNER TO postgres;

CREATE TABLE dominios.secao_ativ_econ (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT secao_ativ_econ_pk PRIMARY KEY (code)
);

INSERT INTO dominios.secao_ativ_econ (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.secao_ativ_econ (code,code_name) VALUES (1,'Indústrias extrativas (1)');
INSERT INTO dominios.secao_ativ_econ (code,code_name) VALUES (2,'Indústrias de transformação (2)');
INSERT INTO dominios.secao_ativ_econ (code,code_name) VALUES (3,'Construção (3)');
INSERT INTO dominios.secao_ativ_econ (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.secao_ativ_econ (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.secao_ativ_econ OWNER TO postgres;

CREATE TABLE dominios.sistema_geodesico (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT sistema_geodesico_pk PRIMARY KEY (code)
);

INSERT INTO dominios.sistema_geodesico (code,code_name) VALUES (1,'SAD-69 (1)');
INSERT INTO dominios.sistema_geodesico (code,code_name) VALUES (2,'SIRGAS2000 (2)');
INSERT INTO dominios.sistema_geodesico (code,code_name) VALUES (3,'WGS-84 (3)');
INSERT INTO dominios.sistema_geodesico (code,code_name) VALUES (4,'Córrego Alegre (4)');
INSERT INTO dominios.sistema_geodesico (code,code_name) VALUES (5,'Astro Chuá (5)');
INSERT INTO dominios.sistema_geodesico (code,code_name) VALUES (6,'Outra referência (6)');
INSERT INTO dominios.sistema_geodesico (code,code_name) VALUES (7,'SAD-69 (96) (7)');
INSERT INTO dominios.sistema_geodesico (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.sistema_geodesico OWNER TO postgres;

CREATE TABLE dominios.tipo_trecho_comunic (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_trecho_comunic_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_trecho_comunic (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_trecho_comunic (code,code_name) VALUES (3,'Sinal de TV (3)');
INSERT INTO dominios.tipo_trecho_comunic (code,code_name) VALUES (4,'Dados (4)');
INSERT INTO dominios.tipo_trecho_comunic (code,code_name) VALUES (7,'Telefônica (7)');
INSERT INTO dominios.tipo_trecho_comunic (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_trecho_comunic (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_trecho_comunic OWNER TO postgres;

CREATE TABLE dominios.administracao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT administracao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.administracao (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.administracao (code,code_name) VALUES (1,'Federal (1)');
INSERT INTO dominios.administracao (code,code_name) VALUES (2,'Estadual/Distrital (2)');
INSERT INTO dominios.administracao (code,code_name) VALUES (3,'Municipal (3)');
INSERT INTO dominios.administracao (code,code_name) VALUES (7,'Concessionada (7)');
INSERT INTO dominios.administracao (code,code_name) VALUES (15,'Privada (15)');
INSERT INTO dominios.administracao (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.administracao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.administracao OWNER TO postgres;

CREATE TABLE dominios.divisao_ativ_econ (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT divisao_ativ_econ_pk PRIMARY KEY (code)
);

INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (1,'Agricultura, pecuário e serviços relacionados (1)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (2,'Silvicultura, exploração florestal e serviços relacionados (2)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (5,'Pesca, aquicultura e serviços relacionados (5)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (10,'Extração de carvão mineral (10)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (11,'Extração de petróleo e serviços relacionados (11)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (13,'Extração de minerais metálicos (13)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (14,'Extração de produtos de minerais não metálicos (14)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (15,'Fabricação alimentícia e bebidas (15)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (16,'Fabricação de produtos do fumo (16)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (17,'Fabricação de produtos têxteis (17)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (18,'Confecção de artigos do vestuário e acessórios (18)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (19,'Preparação de couros e fabricação de artefatos de couro, artigos de viagens e calçados (19)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (20,'Fabricação de produtos de madeira e celulose (20)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (21,'Fabricação de celulose, papel e produtos de papel (21)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (22,'Edição, impressão e reprodução de gravações (22)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (23,'Fabricação de coque, refino de petróleo, elaboração de combustíveis nucleares e produção de álcool (23)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (24,'Fabricação de produtos químicos (24)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (25,'Fabricação de artigos de borracha e material plástico (25)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (26,'Fabricação de produtos de minerais não metálicos (26)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (27,'Metalurgia básica (27)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (28,'Fabricação de produtos de metal, exclusive máquinas e equipamentos (28)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (29,'Fabricação de máquinas e equipamentos (29)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (30,'Fabricação de máquinas de escritório e equipamentos de informática (30)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (31,'Fabricação de máquinas, aparelhos e materiais elétricos (31)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (32,'Fabricação de material eletrônico, e equipamentos de comunicações (32)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (33,'Fabricação de equipamentos de instrumentação médico-hospitalares, instrumentos de precisão e ópticos, equipamentos para automação industrial, cronômetros e relógios (33)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (34,'Fabricação e montagem de veículos automotores, reboques e carrocerias (34)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (35,'Fabricação de outros equipamentos de transporte (35)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (36,'Fabricação de móveis e indústrias diversas (36)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (37,'Reciclagem (37)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (45,'Construção (45)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (50,'Comércio e reparação de veículos automotores e motocicletas e comércio a varejo de combustíveis (50)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (51,'Comércio por atacado e representantes comerciais e agentes do comércio (51)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (52,'Comércio varejista e reparação de objetos pessoais e domésticos (52)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (55,'Alojamento e alimentação (55)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (74,'Serviços prestados principalmente a empresas (organizações) (74)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (92,'Atividades recreativas, culturais e desportivas (92)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.divisao_ativ_econ (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.divisao_ativ_econ OWNER TO postgres;

CREATE TABLE dominios.grupo_ativ_econ (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT grupo_ativ_econ_pk PRIMARY KEY (code)
);

INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (6,'Administração do Estado e da política econômica e social (6)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (8,'Serviços coletivos prestados pela administração (8)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (15,'Seguridade social (15)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (16,'Educação infantil e ensino fundamental (16)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (19,'Ensino médio (19)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (20,'Ensino superior (20)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (23,'Educação profissional e outras atividades de ensino (23)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (30,'Atividades de atenção à saúde (30)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (31,'Serviços veterinários (31)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (32,'Serviço social (32)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.grupo_ativ_econ (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.grupo_ativ_econ OWNER TO postgres;

CREATE TABLE dominios.tipo_via (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_via_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_via (code,code_name) VALUES (1,'Logradouro (1)');
INSERT INTO dominios.tipo_via (code,code_name) VALUES (2,'Rodovia (2)');
INSERT INTO dominios.tipo_via (code,code_name) VALUES (3,'Beco (3)');
INSERT INTO dominios.tipo_via (code,code_name) VALUES (4,'Autoestrada (4)');
INSERT INTO dominios.tipo_via (code,code_name) VALUES (5,'Ligação entre pistas (5)');
INSERT INTO dominios.tipo_via (code,code_name) VALUES (6,'Trecho de entroncamento (6)');
INSERT INTO dominios.tipo_via (code,code_name) VALUES (7,'Servidão (7)');
INSERT INTO dominios.tipo_via (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_via (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_via OWNER TO postgres;

CREATE TABLE dominios.cultivo_predominante (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT cultivo_predominante_pk PRIMARY KEY (code)
);

INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (1,'Milho (1)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (2,'Banana (2)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (3,'Laranja (3)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (4,'Trigo (4)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (6,'Algodão herbáceo (6)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (7,'Cana-de-açúcar (7)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (8,'Fumo (8)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (9,'Soja (9)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (10,'Batata inglesa (10)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (11,'Mandioca, aipim ou macaxeira (11)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (12,'Feijão (12)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (13,'Arroz (13)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (14,'Café (14)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (15,'Cacau (15)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (16,'Erva-mate (16)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (17,'Palmeira (17)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (18,'Açaí (18)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (19,'Seringueira (19)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (20,'Eucalipto (20)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (21,'Acácia (21)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (22,'Algaroba (22)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (23,'Pinus (23)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (24,'Pastagem cultivada (24)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (25,'Hortaliças (25)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (26,'Bracatinga (26)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (27,'Araucária (27)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (28,'Carnaúba (28)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (29,'Pera (29)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (30,'Maçã (30)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (31,'Pêssego (31)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (32,'Juta (32)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (33,'Cebola (33)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (42,'Videira (42)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (43,'Abacate (43)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (44,'Abacaxi ou ananás (44)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (45,'Abóbora (45)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (46,'Acerola (46)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (47,'Alcachofra (47)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (48,'Alfafa (48)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (49,'Algodão arbóreo (49)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (50,'Alho (50)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (51,'Ameixa (51)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (52,'Amendoim (52)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (53,'Amora (53)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (54,'Aveia (54)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (55,'Azeitona (55)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (56,'Azevem (56)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (57,'Batata-doce (57)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (58,'Caju (58)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (59,'Caqui (59)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (60,'Carambola (60)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (61,'Centeio (61)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (62,'Cevada (62)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (63,'Chá-da-índia (63)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (64,'Cidra (64)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (65,'Coco-da-baía (65)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (66,'Cravo-da-índia (66)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (67,'Cupuaçu (67)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (68,'Dendê (68)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (69,'Ervilha (69)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (70,'Fava (70)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (71,'Figo (71)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (72,'Flores (72)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (73,'Girassol (73)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (74,'Goiaba (74)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (75,'Grão-de-Bico (75)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (76,'Guaraná (76)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (77,'Inhame (77)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (78,'Kiwi (78)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (79,'Lentilha (79)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (80,'Limão (80)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (81,'Linho (81)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (82,'Malva (82)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (83,'Mamão (83)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (84,'Mamona (84)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (85,'Manga (85)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (86,'Maracujá (86)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (87,'Marmelo (87)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (88,'Melancia (88)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (89,'Melão (89)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (90,'Milheto (90)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (96,'Não identificado (96)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (100,'Nabo forrageiro (100)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (101,'Noz (101)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (102,'Palmito (102)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (103,'Pepino (103)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (104,'Piaçava (104)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (105,'Pimenta-do-reino (105)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (106,'Plantas ornamentais (106)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (108,'Rami (108)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (110,'Sisal ou agave (110)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (111,'Sorgo (111)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (112,'Tangerina (112)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (113,'Tomate (113)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (114,'Triticale (114)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (115,'Tungue (115)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (116,'Urucum (116)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (117,'Gergelim (117)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (118,'Pupunha (118)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (119,'Lima (119)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (120,'Araçá (120)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (121,'Cultura rotativa (121)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (122,'Mandacaru (122)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (123,'Milho pipoca (123)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (124,'Morango (124)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (125,'Graviola (125)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (126,'Uva (126)');
INSERT INTO dominios.cultivo_predominante (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.cultivo_predominante OWNER TO postgres;

CREATE TABLE dominios.forma_rocha (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT forma_rocha_pk PRIMARY KEY (code)
);

INSERT INTO dominios.forma_rocha (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.forma_rocha (code,code_name) VALUES (21,'Matacão - pedra (21)');
INSERT INTO dominios.forma_rocha (code,code_name) VALUES (22,'Penedo isolado (22)');
INSERT INTO dominios.forma_rocha (code,code_name) VALUES (23,'Área rochosa - lajedo (23)');
INSERT INTO dominios.forma_rocha (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.forma_rocha OWNER TO postgres;

CREATE TABLE dominios.tipo_hierarquia (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_hierarquia_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_hierarquia (code,code_name) VALUES (3,'Municipal (3)');
INSERT INTO dominios.tipo_hierarquia (code,code_name) VALUES (23,'Estadual (23)');
INSERT INTO dominios.tipo_hierarquia (code,code_name) VALUES (24,'Internacional secundário (24)');
INSERT INTO dominios.tipo_hierarquia (code,code_name) VALUES (25,'Internacional de referência (25)');
INSERT INTO dominios.tipo_hierarquia (code,code_name) VALUES (26,'Internacional principal (26)');
INSERT INTO dominios.tipo_hierarquia (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_hierarquia (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_hierarquia OWNER TO postgres;

CREATE TABLE dominios.tipo_transporte (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_transporte_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_transporte (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_transporte (code,code_name) VALUES (21,'Passageiro (21)');
INSERT INTO dominios.tipo_transporte (code,code_name) VALUES (22,'Carga (22)');
INSERT INTO dominios.tipo_transporte (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.tipo_transporte (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_transporte OWNER TO postgres;

CREATE TABLE dominios.sigla_uf (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT sigla_uf_pk PRIMARY KEY (code)
);

INSERT INTO dominios.sigla_uf (code,code_name) VALUES (1,'AC (1)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (2,'AL (2)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (3,'AM (3)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (4,'AP (4)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (5,'BA (5)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (6,'CE (6)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (7,'DF (7)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (8,'ES (8)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (9,'GO (9)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (10,'MA (10)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (11,'MG (11)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (12,'MS (12)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (13,'MT (13)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (14,'PA (14)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (15,'PB (15)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (16,'PE (16)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (17,'PI (17)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (18,'PR (18)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (19,'RJ (19)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (20,'RN (20)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (21,'RO (21)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (22,'RR (22)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (23,'RS (23)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (24,'SC (24)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (25,'SE (25)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (26,'SP (26)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (27,'TO (27)');
INSERT INTO dominios.sigla_uf (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.sigla_uf OWNER TO postgres;

CREATE TABLE dominios.referencial_grav (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT referencial_grav_pk PRIMARY KEY (code)
);

INSERT INTO dominios.referencial_grav (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.referencial_grav (code,code_name) VALUES (1,'Potsdam 1930 (1)');
INSERT INTO dominios.referencial_grav (code,code_name) VALUES (2,'IGSN71 (2)');
INSERT INTO dominios.referencial_grav (code,code_name) VALUES (3,'Absoluto (3)');
INSERT INTO dominios.referencial_grav (code,code_name) VALUES (4,'Local (4)');
INSERT INTO dominios.referencial_grav (code,code_name) VALUES (5,'RGFB (5)');
INSERT INTO dominios.referencial_grav (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.referencial_grav (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.referencial_grav OWNER TO postgres;

CREATE TABLE dominios.tipo_pista_comp (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_pista_comp_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (1,'Atletismo (1)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (2,'Ciclismo (2)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (3,'Motociclismo (3)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (4,'Automobilismo (4)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (5,'Corrida de cavalos (5)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (6,'Bicicross (6)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (7,'Motocross (7)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_pista_comp (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_pista_comp OWNER TO postgres;

CREATE TABLE dominios.estado_fisico (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT estado_fisico_pk PRIMARY KEY (code)
);

INSERT INTO dominios.estado_fisico (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.estado_fisico (code,code_name) VALUES (1,'Líquido (1)');
INSERT INTO dominios.estado_fisico (code,code_name) VALUES (2,'Sólido (2)');
INSERT INTO dominios.estado_fisico (code,code_name) VALUES (3,'Gasoso (3)');
INSERT INTO dominios.estado_fisico (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.estado_fisico (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.estado_fisico OWNER TO postgres;

CREATE TABLE dominios.tipo_travessia (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_travessia_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_travessia (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_travessia (code,code_name) VALUES (1,'Vau natural (1)');
INSERT INTO dominios.tipo_travessia (code,code_name) VALUES (2,'Vau construída (2)');
INSERT INTO dominios.tipo_travessia (code,code_name) VALUES (3,'Bote transportador (3)');
INSERT INTO dominios.tipo_travessia (code,code_name) VALUES (4,'Balsa (4)');
INSERT INTO dominios.tipo_travessia (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_travessia OWNER TO postgres;

CREATE TABLE dominios.tipo_atracad (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_atracad_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (38,'Cais (38)');
INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (39,'Cais flutuante (39)');
INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (40,'Trapiche (40)');
INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (41,'Molhe de atracação (41)');
INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (42,'Píer (42)');
INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (43,'Dolfim (43)');
INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (44,'Desembarcadouro (44)');
INSERT INTO dominios.tipo_atracad (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_atracad OWNER TO postgres;

CREATE TABLE dominios.uso_principal (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT uso_principal_pk PRIMARY KEY (code)
);

INSERT INTO dominios.uso_principal (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (1,'Irrigação (1)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (2,'Abastecimento (2)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (3,'Energia (3)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (4,'Lazer (4)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (5,'Dessedentação animal (5)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (6,'Drenagem (6)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.uso_principal (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.uso_principal OWNER TO postgres;

CREATE TABLE dominios.densidade (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT densidade_pk PRIMARY KEY (code)
);

INSERT INTO dominios.densidade (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.densidade (code,code_name) VALUES (1,'Alta (1)');
INSERT INTO dominios.densidade (code,code_name) VALUES (2,'Baixa (2)');
INSERT INTO dominios.densidade (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.densidade OWNER TO postgres;

CREATE TABLE dominios.atividade (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT atividade_pk PRIMARY KEY (code)
);

INSERT INTO dominios.atividade (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.atividade (code,code_name) VALUES (9,'Prospecção (9)');
INSERT INTO dominios.atividade (code,code_name) VALUES (10,'Produção (10)');
INSERT INTO dominios.atividade (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.atividade OWNER TO postgres;

CREATE TABLE dominios.tipo_ahe (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_ahe_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_ahe (code,code_name) VALUES (1,'UHE (1)');
INSERT INTO dominios.tipo_ahe (code,code_name) VALUES (2,'PCH (2)');
INSERT INTO dominios.tipo_ahe (code,code_name) VALUES (3,'CGH (3)');
INSERT INTO dominios.tipo_ahe (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_ahe OWNER TO postgres;

CREATE TABLE dominios.tipo_vegetacao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_vegetacao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (2,'Vegetação cultivada (2)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (3,'Floresta (3)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (4,'Vegetação de mangue (4)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (5,'Refúgio ecológico (5)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (6,'Campinarana (6)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (7,'Cerrado (7)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (8,'Vegetação de restinga (8)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (9,'Estepe (9)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (10,'Vegetação de brejo ou pântano (10)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (11,'Caatinga (11)');
INSERT INTO dominios.tipo_vegetacao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_vegetacao OWNER TO postgres;

CREATE TABLE dominios.tipo_curva_nivel (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_curva_nivel_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_curva_nivel (code,code_name) VALUES (1,'Mestra (1)');
INSERT INTO dominios.tipo_curva_nivel (code,code_name) VALUES (2,'Normal (2)');
INSERT INTO dominios.tipo_curva_nivel (code,code_name) VALUES (3,'Auxiliar (3)');
INSERT INTO dominios.tipo_curva_nivel (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_curva_nivel OWNER TO postgres;

CREATE TABLE dominios.modalidade (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT modalidade_pk PRIMARY KEY (code)
);

INSERT INTO dominios.modalidade (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.modalidade (code,code_name) VALUES (1,'Radiocomunicação (1)');
INSERT INTO dominios.modalidade (code,code_name) VALUES (2,'Imagem (2)');
INSERT INTO dominios.modalidade (code,code_name) VALUES (3,'Telefonia (3)');
INSERT INTO dominios.modalidade (code,code_name) VALUES (4,'Dados (4)');
INSERT INTO dominios.modalidade (code,code_name) VALUES (5,'Som (5)');
INSERT INTO dominios.modalidade (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.modalidade (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.modalidade OWNER TO postgres;

CREATE TABLE dominios.tipo_instal_militar (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_instal_militar_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (12,'Aquartelamento (12)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (13,'Campo de instrução (13)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (14,'Campo de tiro (14)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (15,'Base aérea (15)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (16,'Distrito naval (16)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (17,'Hotel de trânsito (17)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (18,'Delegacia de serviço militar (18)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (20,'Quartel general (20)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (21,'Posto de vigilância (21)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (22,'Posto de policiamento urbano (22)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (23,'Posto de policiamento rodoviário (23)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (24,'Capitania dos portos (24)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (25,'Base naval (25)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_instal_militar (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_instal_militar OWNER TO postgres;

CREATE TABLE dominios.uso_pista (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT uso_pista_pk PRIMARY KEY (code)
);

INSERT INTO dominios.uso_pista (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.uso_pista (code,code_name) VALUES (6,'Particular (6)');
INSERT INTO dominios.uso_pista (code,code_name) VALUES (11,'Público (11)');
INSERT INTO dominios.uso_pista (code,code_name) VALUES (12,'Militar (12)');
INSERT INTO dominios.uso_pista (code,code_name) VALUES (13,'Público compartilhado com uso militar (13)');
INSERT INTO dominios.uso_pista (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.uso_pista OWNER TO postgres;

CREATE TABLE dominios.tipo_combustivel (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_combustivel_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (1,'Nuclear (1)');
INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (3,'Diesel (3)');
INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (5,'Gás (5)');
INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (7,'Biomassa (7)');
INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (33,'Carvão (33)');
INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_combustivel (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_combustivel OWNER TO postgres;

CREATE TABLE dominios.tipo_equip_agropec (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_equip_agropec_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (1,'Pivô central (1)');
INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (2,'Moinho (2)');
INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (3,'Elevador de grãos (3)');
INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (4,'Moega (4)');
INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (5,'Secador (5)');
INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (6,'Tombador (6)');
INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_equip_agropec (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_equip_agropec OWNER TO postgres;

CREATE TABLE dominios.tipo_org_civil (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_org_civil_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (1,'Policial (1)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (2,'Prisional (2)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (3,'Cartorial (3)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (4,'Gestão (4)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (5,'Eleitoral (5)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (6,'Produção e/ou pesquisa (6)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (7,'Seguridade social (7)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (8,'Câmara municipal (8)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (9,'Assembleia legislativa (9)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (10,'Autarquia (10)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (11,'Delegacia de polícia civil (11)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (12,'Educação (12)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (13,'Fórum (13)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (14,'Fundação (14)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (15,'Procuradoria (15)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (16,'Secretaria (16)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (22,'Prefeitura (22)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_org_civil (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_org_civil OWNER TO postgres;

CREATE TABLE dominios.modal_uso (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT modal_uso_pk PRIMARY KEY (code)
);

INSERT INTO dominios.modal_uso (code,code_name) VALUES (4,'Rodoviário (4)');
INSERT INTO dominios.modal_uso (code,code_name) VALUES (5,'Ferroviário (5)');
INSERT INTO dominios.modal_uso (code,code_name) VALUES (6,'Metroviário (6)');
INSERT INTO dominios.modal_uso (code,code_name) VALUES (7,'Dutos (7)');
INSERT INTO dominios.modal_uso (code,code_name) VALUES (9,'Aeroportuário (9)');
INSERT INTO dominios.modal_uso (code,code_name) VALUES (10,'Hidroviário (10)');
INSERT INTO dominios.modal_uso (code,code_name) VALUES (14,'Portuário (14)');
INSERT INTO dominios.modal_uso (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.modal_uso OWNER TO postgres;

CREATE TABLE dominios.causa (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT causa_pk PRIMARY KEY (code)
);

INSERT INTO dominios.causa (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.causa (code,code_name) VALUES (1,'Canalização (1)');
INSERT INTO dominios.causa (code,code_name) VALUES (2,'Gruta ou fenda (2)');
INSERT INTO dominios.causa (code,code_name) VALUES (3,'Absorção (3)');
INSERT INTO dominios.causa (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.causa OWNER TO postgres;

CREATE TABLE dominios.regime (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT regime_pk PRIMARY KEY (code)
);

INSERT INTO dominios.regime (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.regime (code,code_name) VALUES (1,'Permanente (1)');
INSERT INTO dominios.regime (code,code_name) VALUES (2,'Permanente com grande variação (2)');
INSERT INTO dominios.regime (code,code_name) VALUES (3,'Temporário (3)');
INSERT INTO dominios.regime (code,code_name) VALUES (4,'Temporário com leito permanente (4)');
INSERT INTO dominios.regime (code,code_name) VALUES (5,'Seco (5)');
INSERT INTO dominios.regime (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.regime OWNER TO postgres;

CREATE TABLE dominios.rede_referencia (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT rede_referencia_pk PRIMARY KEY (code)
);

INSERT INTO dominios.rede_referencia (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.rede_referencia (code,code_name) VALUES (2,'Estadual (2)');
INSERT INTO dominios.rede_referencia (code,code_name) VALUES (3,'Municipal (3)');
INSERT INTO dominios.rede_referencia (code,code_name) VALUES (14,'Nacional (14)');
INSERT INTO dominios.rede_referencia (code,code_name) VALUES (15,'Privada (15)');
INSERT INTO dominios.rede_referencia (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.rede_referencia OWNER TO postgres;

CREATE TABLE dominios.especie_trecho_energia (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT especie_trecho_energia_pk PRIMARY KEY (code)
);

INSERT INTO dominios.especie_trecho_energia (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.especie_trecho_energia (code,code_name) VALUES (2,'Transmissão (2)');
INSERT INTO dominios.especie_trecho_energia (code,code_name) VALUES (3,'Distribuição (3)');
INSERT INTO dominios.especie_trecho_energia (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.especie_trecho_energia OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_rod (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_rod_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (8,'Terminal interestadual (8)');
INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (9,'Terminal urbano (9)');
INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (10,'Parada interestadual (10)');
INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (13,'Posto de pedágio (13)');
INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (15,'Administração (15)');
INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (20,'Garagem (20)');
INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_rod (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_rod OWNER TO postgres;

CREATE TABLE dominios.tipo_assentamento_precario (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_assentamento_precario_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_assentamento_precario (code,code_name) VALUES (1,'Cortiço (1)');
INSERT INTO dominios.tipo_assentamento_precario (code,code_name) VALUES (2,'Conjunto habitacional degradado (2)');
INSERT INTO dominios.tipo_assentamento_precario (code,code_name) VALUES (3,'Favela (3)');
INSERT INTO dominios.tipo_assentamento_precario (code,code_name) VALUES (4,'Loteamento irregular da periferia (4)');
INSERT INTO dominios.tipo_assentamento_precario (code,code_name) VALUES (5,'Mocambos (5)');
INSERT INTO dominios.tipo_assentamento_precario (code,code_name) VALUES (6,'Palafitas (6)');
INSERT INTO dominios.tipo_assentamento_precario (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_assentamento_precario (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_assentamento_precario OWNER TO postgres;

CREATE TABLE dominios.tipo_area (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_area_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_area (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (1,'Área de propriedade particular (1)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (2,'Área habitacional (2)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (3,'Área relacionada a dutos (3)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (4,'Área relacionada a edificação agropecuária ou extrativismo vegetal ou pesca (4)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (5,'Área relacionada a edificação de comércio ou serviços (5)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (6,'Área relacionada a edificação de ensino (6)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (7,'Área relacionada a edificação de saúde (7)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (8,'Área relacionada a edificação industrial (8)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (9,'Área relacionada a edificação religiosa (9)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (10,'Área relacionada a energia elétrica (10)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (11,'Área relacionada a equipamentos de desenvolvimento social (11)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (12,'Área relacionada a estação de medição de fenômenos (12)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (13,'Área relacionada ao extrativismo mineral (13)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (14,'Área relacionada a instalação de abastecimento de água (14)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (15,'Área relacionada a instalação de comunicações (15)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (16,'Área relacionada a instalação de estrutura de transporte (16)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (17,'Área relacionada a instalação de saneamento (17)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (18,'Área relacionada ao lazer (18)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (19,'Área relacionada a ruínas de valor histórico (19)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_area (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_area OWNER TO postgres;

CREATE TABLE dominios.tipo_alter_antrop (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_alter_antrop_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (24,'Caixa de empréstimo (24)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (26,'Corte (26)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (27,'Aterro (27)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (28,'Resíduo de bota-fora (28)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (29,'Resíduo sólido em geral (29)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (30,'Canal (30)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (31,'Vala (31)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (32,'Área de extração mineral (32)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_alter_antrop (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_alter_antrop OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_comunic (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_comunic_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_comunic (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_comunic (code,code_name) VALUES (1,'Centro de operações (1)');
INSERT INTO dominios.tipo_edif_comunic (code,code_name) VALUES (2,'Central comutação e transmissão (2)');
INSERT INTO dominios.tipo_edif_comunic (code,code_name) VALUES (3,'Estação rádio base (3)');
INSERT INTO dominios.tipo_edif_comunic (code,code_name) VALUES (4,'Estação repetidora (4)');
INSERT INTO dominios.tipo_edif_comunic (code,code_name) VALUES (5,'Administração (5)');
INSERT INTO dominios.tipo_edif_comunic (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_comunic OWNER TO postgres;

CREATE TABLE dominios.tipo_tunel (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_tunel_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_tunel (code,code_name) VALUES (1,'Túnel (1)');
INSERT INTO dominios.tipo_tunel (code,code_name) VALUES (2,'Passagem subterrânea (2)');
INSERT INTO dominios.tipo_tunel (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_tunel OWNER TO postgres;

CREATE TABLE dominios.nr_linhas (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT nr_linhas_pk PRIMARY KEY (code)
);

INSERT INTO dominios.nr_linhas (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.nr_linhas (code,code_name) VALUES (1,'Simples (1)');
INSERT INTO dominios.nr_linhas (code,code_name) VALUES (2,'Dupla (2)');
INSERT INTO dominios.nr_linhas (code,code_name) VALUES (3,'Múltipla (3)');
INSERT INTO dominios.nr_linhas (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.nr_linhas OWNER TO postgres;

CREATE TABLE dominios.tipo_pto_ref_geod_topo (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_pto_ref_geod_topo_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (1,'Vértice de triangulação - VT (1)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (2,'Referência de nível - RN (2)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (3,'Estação gravimétrica - EG (3)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (4,'Estação de poligonal - EP (4)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (5,'Ponto astronômico - PA (5)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (6,'Ponto barométrico - B (6)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (7,'Ponto trigonométrico - RV (7)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (8,'Ponto de satélite - SAT (8)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_pto_ref_geod_topo (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_pto_ref_geod_topo OWNER TO postgres;

CREATE TABLE dominios.tipo_trecho_ferrov (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_trecho_ferrov_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_trecho_ferrov (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_trecho_ferrov (code,code_name) VALUES (5,'Trecho para bonde (5)');
INSERT INTO dominios.tipo_trecho_ferrov (code,code_name) VALUES (6,'Trecho para aeromóvel (6)');
INSERT INTO dominios.tipo_trecho_ferrov (code,code_name) VALUES (7,'Trecho para trem (7)');
INSERT INTO dominios.tipo_trecho_ferrov (code,code_name) VALUES (8,'Trecho para metrô (8)');
INSERT INTO dominios.tipo_trecho_ferrov (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_trecho_ferrov OWNER TO postgres;

CREATE TABLE dominios.material_predominante (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT material_predominante_pk PRIMARY KEY (code)
);

INSERT INTO dominios.material_predominante (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (4,'Rocha (4)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (12,'Areia (12)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (13,'Areia fina (13)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (14,'Lama (14)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (15,'Argila (15)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (16,'Lodo (16)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (18,'Cascalho (18)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (19,'Seixo (19)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (20,'Coral (20)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (21,'Concha (21)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (22,'Ervas marinhas (22)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (50,'Pedra (50)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.material_predominante (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.material_predominante OWNER TO postgres;

CREATE TABLE dominios.tipo_rep_diplomatica (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_rep_diplomatica_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_rep_diplomatica (code,code_name) VALUES (2,'Embaixada (2)');
INSERT INTO dominios.tipo_rep_diplomatica (code,code_name) VALUES (3,'Consulado (3)');
INSERT INTO dominios.tipo_rep_diplomatica (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_rep_diplomatica OWNER TO postgres;

CREATE TABLE dominios.tipo_embarcacao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_embarcacao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_embarcacao (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_embarcacao (code,code_name) VALUES (2,'Balsa (2)');
INSERT INTO dominios.tipo_embarcacao (code,code_name) VALUES (3,'Lancha (3)');
INSERT INTO dominios.tipo_embarcacao (code,code_name) VALUES (6,'Empurrador-balsa (6)');
INSERT INTO dominios.tipo_embarcacao (code,code_name) VALUES (7,'Embarcação de pequeno porte (7)');
INSERT INTO dominios.tipo_embarcacao (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.tipo_embarcacao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_embarcacao OWNER TO postgres;

CREATE TABLE dominios.tipo_terreno_exposto (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_terreno_exposto_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_terreno_exposto (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_terreno_exposto (code,code_name) VALUES (4,'Pedregoso (4)');
INSERT INTO dominios.tipo_terreno_exposto (code,code_name) VALUES (12,'Areia (12)');
INSERT INTO dominios.tipo_terreno_exposto (code,code_name) VALUES (18,'Cascalho (18)');
INSERT INTO dominios.tipo_terreno_exposto (code,code_name) VALUES (23,'Terra (23)');
INSERT INTO dominios.tipo_terreno_exposto (code,code_name) VALUES (24,'Saibro (24)');
INSERT INTO dominios.tipo_terreno_exposto (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_terreno_exposto OWNER TO postgres;

CREATE TABLE dominios.tipo_delim_fis (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_delim_fis_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_delim_fis (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_delim_fis (code,code_name) VALUES (1,'Cerca (1)');
INSERT INTO dominios.tipo_delim_fis (code,code_name) VALUES (2,'Muro (2)');
INSERT INTO dominios.tipo_delim_fis (code,code_name) VALUES (3,'Mureta (3)');
INSERT INTO dominios.tipo_delim_fis (code,code_name) VALUES (4,'Gradil (4)');
INSERT INTO dominios.tipo_delim_fis (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_delim_fis OWNER TO postgres;

CREATE TABLE dominios.tipo_banco (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_banco_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_banco (code,code_name) VALUES (1,'Fluvial (1)');
INSERT INTO dominios.tipo_banco (code,code_name) VALUES (2,'Marítimo (2)');
INSERT INTO dominios.tipo_banco (code,code_name) VALUES (3,'Lacustre (3)');
INSERT INTO dominios.tipo_banco (code,code_name) VALUES (4,'Cordão arenoso (4)');
INSERT INTO dominios.tipo_banco (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_banco OWNER TO postgres;

CREATE TABLE dominios.local_equip_desenv_social (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT local_equip_desenv_social_pk PRIMARY KEY (code)
);

INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (1,'Terras Indígena (1)');
INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (2,'Terras de População Ribeirinha (2)');
INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (3,'Terras Quilombola (3)');
INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (4,'Rural (4)');
INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (5,'Urbano central (5)');
INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (6,'Urbana periférica (6)');
INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (7,'Outras Comunidades tradicionais (7)');
INSERT INTO dominios.local_equip_desenv_social (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.local_equip_desenv_social OWNER TO postgres;

CREATE TABLE dominios.tipo_ref (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_ref_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_ref (code,code_name) VALUES (1,'Altimétrico (1)');
INSERT INTO dominios.tipo_ref (code,code_name) VALUES (2,'Planimétrico (2)');
INSERT INTO dominios.tipo_ref (code,code_name) VALUES (3,'Planialtimétrico (3)');
INSERT INTO dominios.tipo_ref (code,code_name) VALUES (4,'Gravimétrico (4)');
INSERT INTO dominios.tipo_ref (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_ref OWNER TO postgres;

CREATE TABLE dominios.tipo_pista (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_pista_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_pista (code,code_name) VALUES (9,'Pista de pouso (9)');
INSERT INTO dominios.tipo_pista (code,code_name) VALUES (10,'Pista de taxiamento (10)');
INSERT INTO dominios.tipo_pista (code,code_name) VALUES (11,'Heliponto (11)');
INSERT INTO dominios.tipo_pista (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_pista OWNER TO postgres;

CREATE TABLE dominios.destinacao_cemiterio (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT destinacao_cemiterio_pk PRIMARY KEY (code)
);

INSERT INTO dominios.destinacao_cemiterio (code,code_name) VALUES (2,'Humanos (2)');
INSERT INTO dominios.destinacao_cemiterio (code,code_name) VALUES (3,'Animais (3)');
INSERT INTO dominios.destinacao_cemiterio (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.destinacao_cemiterio OWNER TO postgres;

CREATE TABLE dominios.tipo_fonte_dagua (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_fonte_dagua_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_fonte_dagua (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_fonte_dagua (code,code_name) VALUES (1,'Poço (1)');
INSERT INTO dominios.tipo_fonte_dagua (code,code_name) VALUES (2,'Poço artesiano (2)');
INSERT INTO dominios.tipo_fonte_dagua (code,code_name) VALUES (3,'Olho d''água (3)');
INSERT INTO dominios.tipo_fonte_dagua (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_fonte_dagua OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_aero (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_aero_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (15,'Administração (15)');
INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (26,'Terminal de passageiros (26)');
INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (27,'Terminal de cargas (27)');
INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (28,'Torre de controle (28)');
INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (29,'Hangar (29)');
INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (30,'Serviço de combate a incêndios (SCI) (30)');
INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_aero (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_aero OWNER TO postgres;

CREATE TABLE dominios.tipo_entroncamento (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_entroncamento_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_entroncamento (code,code_name) VALUES (1,'Cruzamento ou injunções simples (1)');
INSERT INTO dominios.tipo_entroncamento (code,code_name) VALUES (2,'Círculo (2)');
INSERT INTO dominios.tipo_entroncamento (code,code_name) VALUES (3,'Trevo (3)');
INSERT INTO dominios.tipo_entroncamento (code,code_name) VALUES (4,'Rótula (4)');
INSERT INTO dominios.tipo_entroncamento (code,code_name) VALUES (5,'Entroncamento ferroviário (5)');
INSERT INTO dominios.tipo_entroncamento (code,code_name) VALUES (99,'Outros tipos de entroncamento em nível (99)');
INSERT INTO dominios.tipo_entroncamento (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_entroncamento OWNER TO postgres;

CREATE TABLE dominios.tipo_est_gerad (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_est_gerad_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_est_gerad (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_est_gerad (code,code_name) VALUES (5,'Eólica (5)');
INSERT INTO dominios.tipo_est_gerad (code,code_name) VALUES (6,'Solar (6)');
INSERT INTO dominios.tipo_est_gerad (code,code_name) VALUES (7,'Maré-motriz (7)');
INSERT INTO dominios.tipo_est_gerad (code,code_name) VALUES (8,'Hidrelétrica (8)');
INSERT INTO dominios.tipo_est_gerad (code,code_name) VALUES (9,'Termelétrica (9)');
INSERT INTO dominios.tipo_est_gerad (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_est_gerad (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_est_gerad OWNER TO postgres;

CREATE TABLE dominios.situacao_juridica (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT situacao_juridica_pk PRIMARY KEY (code)
);

INSERT INTO dominios.situacao_juridica (code,code_name) VALUES (1,'Delimitada (1)');
INSERT INTO dominios.situacao_juridica (code,code_name) VALUES (2,'Declarada (2)');
INSERT INTO dominios.situacao_juridica (code,code_name) VALUES (3,'Homologada ou demarcada (3)');
INSERT INTO dominios.situacao_juridica (code,code_name) VALUES (4,'Regularizada (4)');
INSERT INTO dominios.situacao_juridica (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.situacao_juridica OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_relig (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_relig_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (1,'Igreja (1)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (2,'Templo (2)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (3,'Centro (3)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (4,'Mosteiro (4)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (5,'Convento (5)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (6,'Mesquita (6)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (7,'Sinagoga (7)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (8,'Terreiro (8)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (9,'Capela mortuária (9)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (10,'Administração (10)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_relig (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_relig OWNER TO postgres;

CREATE TABLE dominios.denominacao_associada (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT denominacao_associada_pk PRIMARY KEY (code)
);

INSERT INTO dominios.denominacao_associada (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.denominacao_associada (code,code_name) VALUES (5,'Cristã (5)');
INSERT INTO dominios.denominacao_associada (code,code_name) VALUES (6,'Israelita (6)');
INSERT INTO dominios.denominacao_associada (code,code_name) VALUES (7,'Muçulmana (7)');
INSERT INTO dominios.denominacao_associada (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.denominacao_associada (code,code_name) VALUES (99,'Outras (99)');
INSERT INTO dominios.denominacao_associada (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.denominacao_associada OWNER TO postgres;

CREATE TABLE dominios.tipo_lavoura (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_lavoura_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_lavoura (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_lavoura (code,code_name) VALUES (1,'Perene (1)');
INSERT INTO dominios.tipo_lavoura (code,code_name) VALUES (2,'Semi-perene (2)');
INSERT INTO dominios.tipo_lavoura (code,code_name) VALUES (3,'Anual (3)');
INSERT INTO dominios.tipo_lavoura (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_lavoura OWNER TO postgres;

CREATE TABLE dominios.tipo_ilha (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_ilha_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_ilha (code,code_name) VALUES (1,'Fluvial (1)');
INSERT INTO dominios.tipo_ilha (code,code_name) VALUES (2,'Marítima (2)');
INSERT INTO dominios.tipo_ilha (code,code_name) VALUES (3,'Lacustre (3)');
INSERT INTO dominios.tipo_ilha (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_ilha OWNER TO postgres;

CREATE TABLE dominios.tipo_campo_quadra (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_campo_quadra_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (1,'Futebol (1)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (2,'Basquetebol (2)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (3,'Voleibol (3)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (4,'Pólo (4)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (5,'Hipismo (5)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (6,'Poliesportiva (6)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (7,'Tênis (7)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_campo_quadra (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_campo_quadra OWNER TO postgres;

CREATE TABLE dominios.tipo_ponte (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_ponte_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_ponte (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_ponte (code,code_name) VALUES (1,'Móvel (1)');
INSERT INTO dominios.tipo_ponte (code,code_name) VALUES (2,'Pênsil (2)');
INSERT INTO dominios.tipo_ponte (code,code_name) VALUES (3,'Fixa (3)');
INSERT INTO dominios.tipo_ponte (code,code_name) VALUES (7,'Estaiada (7)');
INSERT INTO dominios.tipo_ponte (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_ponte OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_lazer (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_lazer_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (1,'Estádio (1)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (2,'Ginásio (2)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (3,'Museu (3)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (4,'Teatro (4)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (5,'Anfiteatro (5)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (6,'Espaço de exibição de filmes (6)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (7,'Centro cultural (7)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (8,'Plataforma de pesca (8)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (9,'Arquivo (9)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (10,'Biblioteca (10)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (11,'Centro de documentação (11)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (12,'Circo (12)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (13,'Concha acústica (13)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (14,'Conservatório (14)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (15,'Coreto ou tribuna (15)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (17,'Equipamentos culturais diversos (17)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (18,'Espaço de eventos e/ou cultural (18)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (19,'Galeria (19)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (21,'Quiosque (21)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (22,'Administração (22)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_lazer (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_lazer OWNER TO postgres;

CREATE TABLE dominios.finalidade_galeria_bueiro (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT finalidade_galeria_bueiro_pk PRIMARY KEY (code)
);

INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (1,'Abastecimento animal (1)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (2,'Abastecimento humano (2)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (3,'Abastecimento industrial (3)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (4,'Canalização de águas pluviais (4)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (5,'Canalização de curso d''água (5)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (6,'Canalização de efluentes domésticos (6)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (7,'Canalização de efluentes industriais (7)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (8,'Irrigação (8)');
INSERT INTO dominios.finalidade_galeria_bueiro (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.finalidade_galeria_bueiro OWNER TO postgres;

CREATE TABLE dominios.causa_exposicao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT causa_exposicao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.causa_exposicao (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.causa_exposicao (code,code_name) VALUES (4,'Natural (4)');
INSERT INTO dominios.causa_exposicao (code,code_name) VALUES (5,'Artificial (5)');
INSERT INTO dominios.causa_exposicao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.causa_exposicao OWNER TO postgres;

CREATE TABLE dominios.qualid_agua (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT qualid_agua_pk PRIMARY KEY (code)
);

INSERT INTO dominios.qualid_agua (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.qualid_agua (code,code_name) VALUES (1,'Potável (1)');
INSERT INTO dominios.qualid_agua (code,code_name) VALUES (2,'Não potável (2)');
INSERT INTO dominios.qualid_agua (code,code_name) VALUES (3,'Mineral (3)');
INSERT INTO dominios.qualid_agua (code,code_name) VALUES (4,'Salobra (4)');
INSERT INTO dominios.qualid_agua (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.qualid_agua OWNER TO postgres;

CREATE TABLE dominios.tipo_exposicao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_exposicao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_exposicao (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_exposicao (code,code_name) VALUES (3,'Fechado (3)');
INSERT INTO dominios.tipo_exposicao (code,code_name) VALUES (4,'Coberto (4)');
INSERT INTO dominios.tipo_exposicao (code,code_name) VALUES (5,'Céu aberto (5)');
INSERT INTO dominios.tipo_exposicao (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_exposicao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_exposicao OWNER TO postgres;

CREATE TABLE dominios.especie (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT especie_pk PRIMARY KEY (code)
);

INSERT INTO dominios.especie (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.especie (code,code_name) VALUES (10,'Cipó (10)');
INSERT INTO dominios.especie (code,code_name) VALUES (11,'Bambu (11)');
INSERT INTO dominios.especie (code,code_name) VALUES (17,'Palmeira (17)');
INSERT INTO dominios.especie (code,code_name) VALUES (27,'Araucária (27)');
INSERT INTO dominios.especie (code,code_name) VALUES (37,'Sem predominância (37)');
INSERT INTO dominios.especie (code,code_name) VALUES (96,'Não identificado (96)');
INSERT INTO dominios.especie (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.especie OWNER TO postgres;

CREATE TABLE dominios.tipo_equip_desenv_social (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_equip_desenv_social_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (1,'Banco de alimentos (1)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (2,'Barragem calçadão (2)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (3,'Bolsa verde (3)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (4,'Centro de convivência (4)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (5,'Centro POP (5)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (6,'Centro-dia (6)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (7,'Cisterna subterrânea (7)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (8,'Cisterna de polietileno (8)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (9,'Cisterna de placa (9)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (10,'Cozinha comunitária (10)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (11,'CRAS (11)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (12,'CREAS (12)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (13,'PAA (13)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (14,'PRONAF (14)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (15,'PRONATEC (15)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (16,'Restaurante popular (16)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (17,'Unidade de acolhimento para crianças e adolescentes (17)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (18,'Unidade de acolhimento para crianças e adolescentes (casa de passagem) (18)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (19,'Unidade de acolhimento para idosos (19)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (20,'Unidade de acolhimento para mulheres vítimas de violência (20)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (21,'Unidade de acolhimento para pessoas em situação de rua (21)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_equip_desenv_social (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_equip_desenv_social OWNER TO postgres;

CREATE TABLE dominios.situacao_marco (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT situacao_marco_pk PRIMARY KEY (code)
);

INSERT INTO dominios.situacao_marco (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.situacao_marco (code,code_name) VALUES (1,'Bom (1)');
INSERT INTO dominios.situacao_marco (code,code_name) VALUES (2,'Destruído (2)');
INSERT INTO dominios.situacao_marco (code,code_name) VALUES (3,'Destruído sem chapa (3)');
INSERT INTO dominios.situacao_marco (code,code_name) VALUES (4,'Destruído com chapa danificada (4)');
INSERT INTO dominios.situacao_marco (code,code_name) VALUES (5,'Não encontrado (5)');
INSERT INTO dominios.situacao_marco (code,code_name) VALUES (6,'Não visitado (6)');
INSERT INTO dominios.situacao_marco (code,code_name) VALUES (7,'Não construído (7)');
INSERT INTO dominios.situacao_marco (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.situacao_marco OWNER TO postgres;

CREATE TABLE dominios.tipo_caminho_aereo (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_caminho_aereo_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_caminho_aereo (code,code_name) VALUES (12,'Teleférico (12)');
INSERT INTO dominios.tipo_caminho_aereo (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_caminho_aereo (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_caminho_aereo OWNER TO postgres;

CREATE TABLE dominios.tipo_obst (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_obst_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_obst (code,code_name) VALUES (4,'Natural (4)');
INSERT INTO dominios.tipo_obst (code,code_name) VALUES (5,'Artificial (5)');
INSERT INTO dominios.tipo_obst (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_obst OWNER TO postgres;

CREATE TABLE dominios.tipo_produto_residuo (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_produto_residuo_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (3,'Petróleo (3)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (5,'Gás (5)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (6,'Grãos (6)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (16,'Vinhoto (16)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (17,'Estrume (17)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (18,'Cascalho (18)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (20,'Inseticida (20)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (21,'Folhagens (21)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (22,'Pedra (brita) (22)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (23,'Granito (23)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (24,'Mármore (24)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (25,'Bauxita (25)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (26,'Manganês (26)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (27,'Talco (27)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (28,'Óleo diesel (28)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (29,'Gasolina (29)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (30,'Álcool (30)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (31,'Querosene (31)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (32,'Cobre (32)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (33,'Carvão mineral (33)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (34,'Sal (34)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (35,'Ferro (35)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (36,'Escória (36)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (37,'Ouro (37)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (38,'Diamante (38)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (39,'Prata (39)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (40,'Pedra preciosa (40)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (41,'Forragem (41)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (42,'Areia (42)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (43,'Saibro/piçarra (43)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (45,'Ágata (45)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (46,'Água (46)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (47,'Água marinha (47)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (48,'Água mineral (48)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (49,'Alexandrita (49)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (50,'Ametista (50)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (51,'Amianto (51)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (52,'Argila (52)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (53,'Barita (53)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (54,'Bentonita (54)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (55,'Calcário (55)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (56,'Carvão vegetal (56)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (57,'Caulim (57)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (58,'Chorume (58)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (59,'Chumbo (59)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (60,'Citrino (60)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (61,'Crisoberilo (61)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (62,'Cristal de rocha (62)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (63,'Cromo (63)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (64,'Diatomita (64)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (65,'Dolomito (65)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (66,'Esgoto (66)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (67,'Esmeralda (67)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (68,'Estanho (68)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (69,'Feldspato (69)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (70,'Fosfato (70)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (71,'Gipsita (71)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (72,'Grafita (72)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (73,'Granada (73)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (74,'Lítio (74)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (75,'Lixo domiciliar e comercial (75)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (76,'Lixo séptico (76)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (77,'Lixo tóxico (77)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (78,'Magnesita (78)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (79,'Mica (79)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (80,'Nióbio (80)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (81,'Níquel (81)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (82,'Opala (82)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (83,'Rocha ornamental (83)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (84,'Sal-gema (84)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (85,'Terras raras (85)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (86,'Titânio (86)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (87,'Topázio (87)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (88,'Tório (88)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (89,'Tungstênio (89)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (90,'Turfa (90)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (91,'Turmalina (91)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (92,'Urânio (92)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (93,'Vermiculita (93)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (94,'Zinco (94)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (100,'Zircônio (100)');
INSERT INTO dominios.tipo_produto_residuo (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_produto_residuo OWNER TO postgres;

CREATE TABLE dominios.tipo_massa_dagua (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_massa_dagua_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (1,'Rio (1)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (3,'Oceano (3)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (4,'Baía (4)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (5,'Enseada (5)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (6,'Meandro abandonado (6)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (7,'Lago ou lagoa (7)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (9,'Laguna (9)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (10,'Represa/açude (10)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_massa_dagua (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_massa_dagua OWNER TO postgres;

CREATE TABLE dominios.classe_ativ_econ (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT classe_ativ_econ_pk PRIMARY KEY (code)
);

INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (1,'Produção de energia elétrica (1)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (2,'Transmissão de energia elétrica (2)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (3,'Distribuição de energia elétrica (3)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (4,'Captação, tratamento e distribuição de água (4)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (5,'Telecomunicações (5)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (6,'Administração pública em geral (6)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (7,'Seguridade social (7)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (8,'Regulação das atividades econômicas (8)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (9,'Atividades de apoio à administração pública (9)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (10,'Relações exteriores (10)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (11,'Defesa (11)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (12,'Justiça (12)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (13,'Segurança e ordem pública (13)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (14,'Defesa civil (14)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (16,'Educação infantil - creche (16)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (17,'Educação infantil - pré-escola (17)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (18,'Ensino fundamental (18)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (19,'Ensino médio (19)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (20,'Educação superior - graduação (20)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (21,'Educação superior - graduação e pós-graduação (21)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (22,'Educação superior - pós-graduação e extensão (22)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (23,'Educação profissional de nível técnico (23)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (24,'Educação profissional de nível tecnológico (24)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (25,'Outras atividades de ensino (25)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (26,'Atendimento hospitalar (hospital) (26)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (27,'Atendimento às urgências e emergências (pronto-socorro) (27)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (28,'Atenção ambulatorial (posto e centro de saúde) (28)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (29,'Serviços de complementação diagnóstica ou terapêutica (29)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (30,'Outras atividades relacionadas com atenção à saúde (instituto de pesquisa) (30)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (31,'Serviços veterinários (31)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (32,'Serviços sociais com alojamento (32)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (33,'Serviços sociais sem alojamento (33)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (34,'Limpeza urbana e atividades relacionadas (34)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (35,'Atividades de organizações religiosas (35)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (36,'Regulação das atividades sociais e culturais (36)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (98,'Mista (98)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.classe_ativ_econ (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.classe_ativ_econ OWNER TO postgres;

CREATE TABLE dominios.situacao_agua (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT situacao_agua_pk PRIMARY KEY (code)
);

INSERT INTO dominios.situacao_agua (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.situacao_agua (code,code_name) VALUES (6,'Tratada (6)');
INSERT INTO dominios.situacao_agua (code,code_name) VALUES (7,'Não tratada (7)');
INSERT INTO dominios.situacao_agua (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.situacao_agua OWNER TO postgres;

CREATE TABLE dominios.situacao_em_agua (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT situacao_em_agua_pk PRIMARY KEY (code)
);

INSERT INTO dominios.situacao_em_agua (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.situacao_em_agua (code,code_name) VALUES (4,'Emerso (4)');
INSERT INTO dominios.situacao_em_agua (code,code_name) VALUES (5,'Submerso (5)');
INSERT INTO dominios.situacao_em_agua (code,code_name) VALUES (7,'Cobre e descobre (7)');
INSERT INTO dominios.situacao_em_agua (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.situacao_em_agua OWNER TO postgres;

CREATE TABLE dominios.auxiliar (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT auxiliar_pk PRIMARY KEY (code)
);

INSERT INTO dominios.auxiliar (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.auxiliar (code,code_name) VALUES (1,'Sim (1)');
INSERT INTO dominios.auxiliar (code,code_name) VALUES (2,'Não (2)');
INSERT INTO dominios.auxiliar (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.auxiliar OWNER TO postgres;

CREATE TABLE dominios.situacao_fisica (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT situacao_fisica_pk PRIMARY KEY (code)
);

INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (1,'Abandonada (1)');
INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (2,'Destruída (2)');
INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (3,'Em construção (3)');
INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (4,'Planejada (4)');
INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (5,'Construída (5)');
INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (6,'Construída, mas em obras (6)');
INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.situacao_fisica (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.situacao_fisica OWNER TO postgres;

CREATE TABLE dominios.tipo_pavimentacao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_pavimentacao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (2,'Asfalto (2)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (3,'Placa de concreto (3)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (4,'Pedra regular (4)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (5,'Ladrilho de concreto (5)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (6,'Paralelepípedo (6)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (7,'Pedra irregular (7)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_pavimentacao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_pavimentacao OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_energia (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_energia_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_energia (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_energia (code,code_name) VALUES (1,'Administração (1)');
INSERT INTO dominios.tipo_edif_energia (code,code_name) VALUES (2,'Oficinas (2)');
INSERT INTO dominios.tipo_edif_energia (code,code_name) VALUES (3,'Segurança (3)');
INSERT INTO dominios.tipo_edif_energia (code,code_name) VALUES (4,'Depósito (4)');
INSERT INTO dominios.tipo_edif_energia (code,code_name) VALUES (5,'Chaminé (5)');
INSERT INTO dominios.tipo_edif_energia (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_energia (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_energia OWNER TO postgres;

CREATE TABLE dominios.trafego (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT trafego_pk PRIMARY KEY (code)
);

INSERT INTO dominios.trafego (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.trafego (code,code_name) VALUES (1,'Permanente (1)');
INSERT INTO dominios.trafego (code,code_name) VALUES (2,'Periódico (2)');
INSERT INTO dominios.trafego (code,code_name) VALUES (4,'Temporário (4)');
INSERT INTO dominios.trafego (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.trafego OWNER TO postgres;

CREATE TABLE dominios.tipo_manguezal (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_manguezal_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_manguezal (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_manguezal (code,code_name) VALUES (2,'Manguezal (2)');
INSERT INTO dominios.tipo_manguezal (code,code_name) VALUES (3,'Manguezal tipo apicum (3)');
INSERT INTO dominios.tipo_manguezal (code,code_name) VALUES (4,'Manguezal tipo salgado (4)');
INSERT INTO dominios.tipo_manguezal (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_manguezal OWNER TO postgres;

CREATE TABLE dominios.posicao_rel_edific (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT posicao_rel_edific_pk PRIMARY KEY (code)
);

INSERT INTO dominios.posicao_rel_edific (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.posicao_rel_edific (code,code_name) VALUES (14,'Isolada (14)');
INSERT INTO dominios.posicao_rel_edific (code,code_name) VALUES (17,'Adjacente à edificação (17)');
INSERT INTO dominios.posicao_rel_edific (code,code_name) VALUES (18,'Sobre edificação (18)');
INSERT INTO dominios.posicao_rel_edific (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.posicao_rel_edific OWNER TO postgres;

CREATE TABLE dominios.posicao_relativa (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT posicao_relativa_pk PRIMARY KEY (code)
);

INSERT INTO dominios.posicao_relativa (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.posicao_relativa (code,code_name) VALUES (2,'Superfície (2)');
INSERT INTO dominios.posicao_relativa (code,code_name) VALUES (3,'Elevada (3)');
INSERT INTO dominios.posicao_relativa (code,code_name) VALUES (4,'Emersa (4)');
INSERT INTO dominios.posicao_relativa (code,code_name) VALUES (5,'Submersa (5)');
INSERT INTO dominios.posicao_relativa (code,code_name) VALUES (6,'Subterrânea (6)');
INSERT INTO dominios.posicao_relativa (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.posicao_relativa OWNER TO postgres;

CREATE TABLE dominios.tipo_campo (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_campo_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_campo (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_campo (code,code_name) VALUES (1,'Sujo (1)');
INSERT INTO dominios.tipo_campo (code,code_name) VALUES (2,'Limpo (2)');
INSERT INTO dominios.tipo_campo (code,code_name) VALUES (3,'Rupestre (3)');
INSERT INTO dominios.tipo_campo (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_campo OWNER TO postgres;

CREATE TABLE dominios.tipo_passag_viad (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_passag_viad_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_passag_viad (code,code_name) VALUES (5,'Passagem elevada (5)');
INSERT INTO dominios.tipo_passag_viad (code,code_name) VALUES (6,'Viaduto (6)');
INSERT INTO dominios.tipo_passag_viad (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_passag_viad OWNER TO postgres;

CREATE TABLE dominios.tipo_queda (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_queda_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_queda (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_queda (code,code_name) VALUES (1,'Cachoeira (1)');
INSERT INTO dominios.tipo_queda (code,code_name) VALUES (2,'Salto (2)');
INSERT INTO dominios.tipo_queda (code,code_name) VALUES (3,'Catarata (3)');
INSERT INTO dominios.tipo_queda (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_queda OWNER TO postgres;

CREATE TABLE dominios.tipo_conteudo (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_conteudo_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_conteudo (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_conteudo (code,code_name) VALUES (1,'Insumo (1)');
INSERT INTO dominios.tipo_conteudo (code,code_name) VALUES (2,'Produto (2)');
INSERT INTO dominios.tipo_conteudo (code,code_name) VALUES (3,'Resíduo (3)');
INSERT INTO dominios.tipo_conteudo (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_conteudo OWNER TO postgres;

CREATE TABLE dominios.tipo_localidade (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_localidade_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (1,'Aglomerado rural isolado - Núcleo (1)');
INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (2,'Aglomerado rural isolado - Povoado (2)');
INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (3,'Outros aglomerados rurais (3)');
INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (4,'Capital Estadual (4)');
INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (5,'Cidade (5)');
INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (6,'Vila (6)');
INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (7,'Capital Federal (7)');
INSERT INTO dominios.tipo_localidade (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_localidade OWNER TO postgres;

CREATE TABLE dominios.proximidade (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT proximidade_pk PRIMARY KEY (code)
);

INSERT INTO dominios.proximidade (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.proximidade (code,code_name) VALUES (14,'Isolada (14)');
INSERT INTO dominios.proximidade (code,code_name) VALUES (15,'Adjacente (15)');
INSERT INTO dominios.proximidade (code,code_name) VALUES (16,'Coincidente (16)');
INSERT INTO dominios.proximidade (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.proximidade OWNER TO postgres;

CREATE TABLE dominios.tipo_ext_min (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_ext_min_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_ext_min (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_ext_min (code,code_name) VALUES (1,'Poço para água subterrânea (1)');
INSERT INTO dominios.tipo_ext_min (code,code_name) VALUES (4,'Mina (4)');
INSERT INTO dominios.tipo_ext_min (code,code_name) VALUES (5,'Garimpo (5)');
INSERT INTO dominios.tipo_ext_min (code,code_name) VALUES (6,'Salina (6)');
INSERT INTO dominios.tipo_ext_min (code,code_name) VALUES (8,'Poço de petróleo (8)');
INSERT INTO dominios.tipo_ext_min (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_ext_min (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_ext_min OWNER TO postgres;

CREATE TABLE dominios.tipo_fundeadouro (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_fundeadouro_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_fundeadouro (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_fundeadouro (code,code_name) VALUES (1,'Com limite definido (1)');
INSERT INTO dominios.tipo_fundeadouro (code,code_name) VALUES (2,'Sem limite definido (2)');
INSERT INTO dominios.tipo_fundeadouro (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_fundeadouro OWNER TO postgres;

CREATE TABLE dominios.classificacao_porte (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT classificacao_porte_pk PRIMARY KEY (code)
);

INSERT INTO dominios.classificacao_porte (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.classificacao_porte (code,code_name) VALUES (1,'Arbórea (1)');
INSERT INTO dominios.classificacao_porte (code,code_name) VALUES (2,'Arbustiva (2)');
INSERT INTO dominios.classificacao_porte (code,code_name) VALUES (3,'Herbácea (3)');
INSERT INTO dominios.classificacao_porte (code,code_name) VALUES (4,'Rasteira (4)');
INSERT INTO dominios.classificacao_porte (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.classificacao_porte OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_comerc_serv (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_comerc_serv_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (3,'Centro comercial (3)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (4,'Mercado público (4)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (5,'Centro de convenções (5)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (6,'Banca de jornal (6)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (7,'Hotel (7)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (8,'Restaurante (8)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (9,'Comércio de carnes (9)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (10,'Farmácia (10)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (11,'Banco (11)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (12,'Loja de conveniência (12)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (13,'Loja de materiais de construção e/ou ferragem (13)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (14,'Loja de móveis (14)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (15,'Loja de roupas e/ou tecidos (15)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (16,'Motel (16)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (17,'Oficina mecânica (17)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (18,'Outros comércios (18)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (19,'Posto de combustível (19)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (20,'Pousada (20)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (21,'Quiosque (21)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (22,'Quitanda (22)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (23,'Supermercado (23)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (24,'Venda de veículos (24)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (25,'Administração (25)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (26,'Centro de exposições (26)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (99,'Outros serviços (99)');
INSERT INTO dominios.tipo_edif_comerc_serv (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_comerc_serv OWNER TO postgres;

CREATE TABLE dominios.situacao_costa (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT situacao_costa_pk PRIMARY KEY (code)
);

INSERT INTO dominios.situacao_costa (code,code_name) VALUES (10,'Contígua (10)');
INSERT INTO dominios.situacao_costa (code,code_name) VALUES (11,'Afastada (11)');
INSERT INTO dominios.situacao_costa (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.situacao_costa OWNER TO postgres;

CREATE TABLE dominios.finalidade (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT finalidade_pk PRIMARY KEY (code)
);

INSERT INTO dominios.finalidade (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.finalidade (code,code_name) VALUES (1,'Comercial (1)');
INSERT INTO dominios.finalidade (code,code_name) VALUES (2,'Serviço (2)');
INSERT INTO dominios.finalidade (code,code_name) VALUES (4,'Residencial (4)');
INSERT INTO dominios.finalidade (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.finalidade (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.finalidade OWNER TO postgres;

CREATE TABLE dominios.referencial_altim (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT referencial_altim_pk PRIMARY KEY (code)
);

INSERT INTO dominios.referencial_altim (code,code_name) VALUES (1,'Torres (1)');
INSERT INTO dominios.referencial_altim (code,code_name) VALUES (2,'Imbituba (2)');
INSERT INTO dominios.referencial_altim (code,code_name) VALUES (3,'Santana (3)');
INSERT INTO dominios.referencial_altim (code,code_name) VALUES (99,'Outra referência (99)');
INSERT INTO dominios.referencial_altim (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.referencial_altim OWNER TO postgres;

CREATE TABLE dominios.tipo_pto_est_med (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_pto_est_med_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (1,'Climatológica principal - CP (1)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (2,'Climatológica auxiliar - CA (2)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (3,'Agroclimatológica - AC (3)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (4,'Pluviométrica - PL (4)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (5,'Eólica - EO (5)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (6,'Evaporimétrica - EV (6)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (7,'Solarimétrica - SL (7)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (8,'Radar metereológico - RD (8)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (9,'Radiossonda - RS (9)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (10,'Fluviométrica - FL (10)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (11,'Maregráfica - MA (11)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (12,'Marés terrestres-crosta (12)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (13,'Metero-maregráfica (13)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (14,'Hidrológica (14)');
INSERT INTO dominios.tipo_pto_est_med (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_pto_est_med OWNER TO postgres;

CREATE TABLE dominios.tipo_recife (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_recife_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_recife (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_recife (code,code_name) VALUES (1,'Arenito (1)');
INSERT INTO dominios.tipo_recife (code,code_name) VALUES (2,'Rochoso (2)');
INSERT INTO dominios.tipo_recife (code,code_name) VALUES (20,'Coral (20)');
INSERT INTO dominios.tipo_recife (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_recife OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_agropec (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_agropec_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (4,'Administração (4)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (12,'Sede operacional de fazenda (12)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (13,'Aviário (13)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (14,'Apiário (14)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (15,'Viveiro de plantas (15)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (16,'Viveiro para aquicultura (16)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (17,'Pocilga (17)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (18,'Curral (18)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_agropec (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_agropec OWNER TO postgres;

CREATE TABLE dominios.tipo_trecho_drenagem (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_trecho_drenagem_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_trecho_drenagem (code,code_name) VALUES (4,'Curso d''água (4)');
INSERT INTO dominios.tipo_trecho_drenagem (code,code_name) VALUES (5,'Pluvial (5)');
INSERT INTO dominios.tipo_trecho_drenagem (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_trecho_drenagem OWNER TO postgres;

CREATE TABLE dominios.tipo_cemiterio (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_cemiterio_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (1,'Crematório (1)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (2,'Parque (2)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (3,'Vertical (3)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (4,'Comum (4)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (5,'Túmulo isolado (5)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (6,'Horizontal/vertical (6)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_cemiterio (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_cemiterio OWNER TO postgres;

CREATE TABLE dominios.tipo_unid_uso_sust (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_unid_uso_sust_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_unid_uso_sust (code,code_name) VALUES (1,'Área de proteção ambiental - APA (1)');
INSERT INTO dominios.tipo_unid_uso_sust (code,code_name) VALUES (2,'Área de relevante interesse ecológico – ARIE (2)');
INSERT INTO dominios.tipo_unid_uso_sust (code,code_name) VALUES (3,'Floresta – FLO (3)');
INSERT INTO dominios.tipo_unid_uso_sust (code,code_name) VALUES (4,'Reserva de desenvolvimento sustentável – RDS (4)');
INSERT INTO dominios.tipo_unid_uso_sust (code,code_name) VALUES (5,'Reserva extrativista (5)');
INSERT INTO dominios.tipo_unid_uso_sust (code,code_name) VALUES (6,'Reserva de fauna – REFAU (6)');
INSERT INTO dominios.tipo_unid_uso_sust (code,code_name) VALUES (7,'Reserva particular de patrimônio natural – RPPN (7)');
INSERT INTO dominios.tipo_unid_uso_sust (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_unid_uso_sust OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_port (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_port_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (15,'Administração (15)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (26,'Terminal de passageiros (26)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (27,'Terminal de cargas (27)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (32,'Armazém (32)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (33,'Estaleiro (33)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (34,'Dique de estaleiro (34)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (35,'Rampa transportadora (35)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (36,'Carreira (36)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (37,'Terminal de uso privativo (37)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_port (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_port OWNER TO postgres;

CREATE TABLE dominios.tipo_plataforma (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_plataforma_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_plataforma (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_plataforma (code,code_name) VALUES (3,'Petróleo (3)');
INSERT INTO dominios.tipo_plataforma (code,code_name) VALUES (5,'Gás (5)');
INSERT INTO dominios.tipo_plataforma (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.tipo_plataforma (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_plataforma OWNER TO postgres;

CREATE TABLE dominios.tipo_posto_fisc (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_posto_fisc_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_posto_fisc (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_posto_fisc (code,code_name) VALUES (10,'Tributação (10)');
INSERT INTO dominios.tipo_posto_fisc (code,code_name) VALUES (12,'Fiscalização sanitária (12)');
INSERT INTO dominios.tipo_posto_fisc (code,code_name) VALUES (13,'Posto de pesagem (13)');
INSERT INTO dominios.tipo_posto_fisc (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.tipo_posto_fisc (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_posto_fisc (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_posto_fisc OWNER TO postgres;

CREATE TABLE dominios.tipo_unid_protegida (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_unid_protegida_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_unid_protegida (code,code_name) VALUES (1,'Unidade de conservação não SNUC (1)');
INSERT INTO dominios.tipo_unid_protegida (code,code_name) VALUES (2,'Unidade de proteção integral (2)');
INSERT INTO dominios.tipo_unid_protegida (code,code_name) VALUES (3,'Unidade de uso sustentável (3)');
INSERT INTO dominios.tipo_unid_protegida (code,code_name) VALUES (4,'Unidade de conservação (4)');
INSERT INTO dominios.tipo_unid_protegida (code,code_name) VALUES (5,'Outras unidades protegidas (5)');
INSERT INTO dominios.tipo_unid_protegida (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_unid_protegida OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_abast (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_abast_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_abast (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_abast (code,code_name) VALUES (1,'Captação (1)');
INSERT INTO dominios.tipo_edif_abast (code,code_name) VALUES (2,'Tratamento (2)');
INSERT INTO dominios.tipo_edif_abast (code,code_name) VALUES (3,'Recalque (3)');
INSERT INTO dominios.tipo_edif_abast (code,code_name) VALUES (4,'Administração (4)');
INSERT INTO dominios.tipo_edif_abast (code,code_name) VALUES (98,'Misto (98)');
INSERT INTO dominios.tipo_edif_abast (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_abast (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_abast OWNER TO postgres;

CREATE TABLE dominios.proc_extracao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT proc_extracao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.proc_extracao (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.proc_extracao (code,code_name) VALUES (1,'Mecanizado (1)');
INSERT INTO dominios.proc_extracao (code,code_name) VALUES (2,'Manual (2)');
INSERT INTO dominios.proc_extracao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.proc_extracao OWNER TO postgres;

CREATE TABLE dominios.tipo_area_umida (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_area_umida_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_area_umida (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_area_umida (code,code_name) VALUES (3,'Lamacento (3)');
INSERT INTO dominios.tipo_area_umida (code,code_name) VALUES (4,'Arenoso (4)');
INSERT INTO dominios.tipo_area_umida (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_area_umida OWNER TO postgres;

CREATE TABLE dominios.mat_transp (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT mat_transp_pk PRIMARY KEY (code)
);

INSERT INTO dominios.mat_transp (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (1,'Água (1)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (2,'Óleo (2)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (3,'Petróleo (3)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (4,'Nafta (4)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (5,'Gás (5)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (6,'Grãos (6)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (7,'Minério (7)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (8,'Efluentes (8)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (9,'Esgoto (9)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (29,'Gasolina (29)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (30,'Álcool (30)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (31,'Querosene (31)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.mat_transp (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.mat_transp OWNER TO postgres;

CREATE TABLE dominios.tipo_poco_mina (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_poco_mina_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_poco_mina (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_poco_mina (code,code_name) VALUES (2,'Horizontal (2)');
INSERT INTO dominios.tipo_poco_mina (code,code_name) VALUES (3,'Vertical (3)');
INSERT INTO dominios.tipo_poco_mina (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.tipo_poco_mina (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_poco_mina OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_metro_ferrov (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_metro_ferrov_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (15,'Administração (15)');
INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (16,'Estação ferroviária de passageiros (16)');
INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (17,'Estação metroviária (17)');
INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (18,'Terminal ferroviário de cargas (18)');
INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (19,'Terminal ferroviário de passageiros e cargas (19)');
INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (20,'Oficina de manutenção (20)');
INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_metro_ferrov (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_metro_ferrov OWNER TO postgres;

CREATE TABLE dominios.nivel_atencao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT nivel_atencao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.nivel_atencao (code,code_name) VALUES (5,'Primário (5)');
INSERT INTO dominios.nivel_atencao (code,code_name) VALUES (6,'Secundário (6)');
INSERT INTO dominios.nivel_atencao (code,code_name) VALUES (7,'Terciário (7)');
INSERT INTO dominios.nivel_atencao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.nivel_atencao OWNER TO postgres;

CREATE TABLE dominios.setor (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT setor_pk PRIMARY KEY (code)
);

INSERT INTO dominios.setor (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.setor (code,code_name) VALUES (1,'Energético (1)');
INSERT INTO dominios.setor (code,code_name) VALUES (2,'Econômico (2)');
INSERT INTO dominios.setor (code,code_name) VALUES (3,'Abastecimento de água (3)');
INSERT INTO dominios.setor (code,code_name) VALUES (4,'Saneamento básico (4)');
INSERT INTO dominios.setor (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.setor OWNER TO postgres;

CREATE TABLE dominios.revestimento (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT revestimento_pk PRIMARY KEY (code)
);

INSERT INTO dominios.revestimento (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.revestimento (code,code_name) VALUES (1,'Sem revestimento (leito natural) (1)');
INSERT INTO dominios.revestimento (code,code_name) VALUES (2,'Revestimento primário (solto) (2)');
INSERT INTO dominios.revestimento (code,code_name) VALUES (3,'Pavimentado (3)');
INSERT INTO dominios.revestimento (code,code_name) VALUES (4,'Madeira (4)');
INSERT INTO dominios.revestimento (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.revestimento (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.revestimento OWNER TO postgres;

CREATE TABLE dominios.finalidade_deposito (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT finalidade_deposito_pk PRIMARY KEY (code)
);

INSERT INTO dominios.finalidade_deposito (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.finalidade_deposito (code,code_name) VALUES (2,'Tratamento (2)');
INSERT INTO dominios.finalidade_deposito (code,code_name) VALUES (3,'Recalque (3)');
INSERT INTO dominios.finalidade_deposito (code,code_name) VALUES (4,'Distribuição (4)');
INSERT INTO dominios.finalidade_deposito (code,code_name) VALUES (8,'Armazenamento (8)');
INSERT INTO dominios.finalidade_deposito (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.finalidade_deposito OWNER TO postgres;

CREATE TABLE dominios.tipo_poste (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_poste_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_poste (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_poste (code,code_name) VALUES (2,'Iluminação (2)');
INSERT INTO dominios.tipo_poste (code,code_name) VALUES (3,'Ornamental (3)');
INSERT INTO dominios.tipo_poste (code,code_name) VALUES (4,'Rede elétrica (4)');
INSERT INTO dominios.tipo_poste (code,code_name) VALUES (5,'Sinalização (5)');
INSERT INTO dominios.tipo_poste (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_poste (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_poste OWNER TO postgres;

CREATE TABLE dominios.unidade_volume (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT unidade_volume_pk PRIMARY KEY (code)
);

INSERT INTO dominios.unidade_volume (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.unidade_volume (code,code_name) VALUES (1,'Litro (1)');
INSERT INTO dominios.unidade_volume (code,code_name) VALUES (2,'Metro cúbico (2)');
INSERT INTO dominios.unidade_volume (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.unidade_volume OWNER TO postgres;

CREATE TABLE dominios.tipo_edif_saneam (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_edif_saneam_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_edif_saneam (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.tipo_edif_saneam (code,code_name) VALUES (3,'Recalque (3)');
INSERT INTO dominios.tipo_edif_saneam (code,code_name) VALUES (5,'Tratamento de esgoto (5)');
INSERT INTO dominios.tipo_edif_saneam (code,code_name) VALUES (6,'Usina de reciclagem (6)');
INSERT INTO dominios.tipo_edif_saneam (code,code_name) VALUES (7,'Incinerador (7)');
INSERT INTO dominios.tipo_edif_saneam (code,code_name) VALUES (8,'Administração (8)');
INSERT INTO dominios.tipo_edif_saneam (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_edif_saneam (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_edif_saneam OWNER TO postgres;

CREATE TABLE dominios.tipo_sum_vert (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_sum_vert_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_sum_vert (code,code_name) VALUES (1,'Sumidouro (1)');
INSERT INTO dominios.tipo_sum_vert (code,code_name) VALUES (2,'Vertedouro (2)');
INSERT INTO dominios.tipo_sum_vert (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_sum_vert OWNER TO postgres;

CREATE TABLE dominios.tipo_elevador (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_elevador_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_elevador (code,code_name) VALUES (2,'Inclinado (2)');
INSERT INTO dominios.tipo_elevador (code,code_name) VALUES (3,'Vertical (3)');
INSERT INTO dominios.tipo_elevador (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_elevador OWNER TO postgres;

CREATE TABLE dominios.tipo_elem_nat (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_elem_nat_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (1,'Serra (1)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (2,'Morro (2)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (3,'Montanha (3)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (4,'Chapada (4)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (5,'Maciço (5)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (6,'Planalto (6)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (7,'Planície (7)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (8,'Escarpa (8)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (9,'Península (9)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (10,'Ponta (10)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (11,'Cabo (11)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (12,'Praia (12)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (13,'Falésia (13)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (14,'Talude (14)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (15,'Caverna (15)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (16,'Dolina (16)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (17,'Duna (17)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (18,'Falha (18)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (19,'Fenda (19)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (20,'Gruta (20)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (21,'Ilha (21)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (22,'Pico (22)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (23,'Rocha (23)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.tipo_elem_nat (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_elem_nat OWNER TO postgres;

CREATE TABLE dominios.mat_condutor (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT mat_condutor_pk PRIMARY KEY (code)
);

INSERT INTO dominios.mat_condutor (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.mat_condutor (code,code_name) VALUES (1,'Fibra ótica (1)');
INSERT INTO dominios.mat_condutor (code,code_name) VALUES (2,'Fio metálico (2)');
INSERT INTO dominios.mat_condutor (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.mat_condutor (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.mat_condutor OWNER TO postgres;

CREATE TABLE dominios.mat_constr (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT mat_constr_pk PRIMARY KEY (code)
);

INSERT INTO dominios.mat_constr (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (1,'Alvenaria (1)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (2,'Concreto (2)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (3,'Metal (3)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (4,'Rocha (4)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (5,'Madeira (5)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (8,'Fibra (8)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (23,'Terra (23)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.mat_constr (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.mat_constr OWNER TO postgres;

CREATE TABLE dominios.situacao_espacial (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT situacao_espacial_pk PRIMARY KEY (code)
);

INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (2,'Subterrânea (2)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (4,'Superposta nível 2 (4)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (5,'Nível do solo (5)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (7,'Superposta nível 3 (7)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (12,'Adjacente (12)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (13,'Superposta nível 1 (13)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (97,'Não aplicável (97)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (99,'Outra (99)');
INSERT INTO dominios.situacao_espacial (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.situacao_espacial OWNER TO postgres;

CREATE TABLE dominios.tipo_associado (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT tipo_associado_pk PRIMARY KEY (code)
);

INSERT INTO dominios.tipo_associado (code,code_name) VALUES (1,'Cidade (1)');
INSERT INTO dominios.tipo_associado (code,code_name) VALUES (4,'Vila (4)');
INSERT INTO dominios.tipo_associado (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.tipo_associado OWNER TO postgres;

CREATE TABLE dominios.finalidade_patio (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT finalidade_patio_pk PRIMARY KEY (code)
);

INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (2,'Depósito temporário de cargas e contêineres (2)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (3,'Estacionamento de veículos (3)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (4,'Estacionamento de locomotivas (4)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (5,'Estacionamento de aeronaves (5)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (6,'Manobra de cargas (6)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (7,'Manobra de veículos em geral (7)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (8,'Manutenção (8)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.finalidade_patio (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.finalidade_patio OWNER TO postgres;

CREATE TABLE dominios.jurisdicao (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT jurisdicao_pk PRIMARY KEY (code)
);

INSERT INTO dominios.jurisdicao (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.jurisdicao (code,code_name) VALUES (1,'Federal (1)');
INSERT INTO dominios.jurisdicao (code,code_name) VALUES (2,'Estadual/Distrital (2)');
INSERT INTO dominios.jurisdicao (code,code_name) VALUES (3,'Municipal (3)');
INSERT INTO dominios.jurisdicao (code,code_name) VALUES (4,'Internacional (4)');
INSERT INTO dominios.jurisdicao (code,code_name) VALUES (8,'Propriedade particular (8)');
INSERT INTO dominios.jurisdicao (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.jurisdicao OWNER TO postgres;

CREATE TABLE dominios.destinado_a (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT destinado_a_pk PRIMARY KEY (code)
);

INSERT INTO dominios.destinado_a (code,code_name) VALUES (0,'Desconhecido (0)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (5,'Madeira (5)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (18,'Açaí (18)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (34,'Turfa (34)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (35,'Látex (35)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (36,'Castanha (36)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (37,'Carnaúba (37)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (38,'Coco (38)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (39,'Jaborandi (39)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (40,'Palmito (40)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (41,'Babaçu (41)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (43,'Pecuária (43)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (44,'Pesca (44)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (99,'Outros (99)');
INSERT INTO dominios.destinado_a (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.destinado_a OWNER TO postgres;

CREATE TABLE dominios.condicao_terreno (
	 code smallint NOT NULL,
	 code_name text NOT NULL,
	 CONSTRAINT condicao_terreno_pk PRIMARY KEY (code)
);

INSERT INTO dominios.condicao_terreno (code,code_name) VALUES (0,'Desconhecida (0)');
INSERT INTO dominios.condicao_terreno (code,code_name) VALUES (1,'Seco (1)');
INSERT INTO dominios.condicao_terreno (code,code_name) VALUES (2,'Irrigado (2)');
INSERT INTO dominios.condicao_terreno (code,code_name) VALUES (3,'Inundado (3)');
INSERT INTO dominios.condicao_terreno (code,code_name) VALUES (9999,'A SER PREENCHIDO (9999)');

ALTER TABLE dominios.condicao_terreno OWNER TO postgres;

CREATE TABLE edgv.aer_pista_ponto_pouso_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipopista smallint NOT NULL,
	 revestimento smallint NOT NULL,
	 usopista smallint NOT NULL,
	 homologacao smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 largura real,
	 extensao real,
	 altitude real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT aer_pista_ponto_pouso_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX aer_pista_ponto_pouso_l_geom ON edgv.aer_pista_ponto_pouso_l USING gist (geom);

ALTER TABLE edgv.aer_pista_ponto_pouso_l OWNER TO postgres;

ALTER TABLE edgv.aer_pista_ponto_pouso_l
	 ADD CONSTRAINT aer_pista_ponto_pouso_l_tipopista_fk FOREIGN KEY (tipopista)
	 REFERENCES dominios.tipo_pista (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_l ALTER COLUMN tipopista SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_l
	 ADD CONSTRAINT aer_pista_ponto_pouso_l_revestimento_fk FOREIGN KEY (revestimento)
	 REFERENCES dominios.revestimento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_l ALTER COLUMN revestimento SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_l
	 ADD CONSTRAINT aer_pista_ponto_pouso_l_usopista_fk FOREIGN KEY (usopista)
	 REFERENCES dominios.uso_pista (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_l ALTER COLUMN usopista SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_l
	 ADD CONSTRAINT aer_pista_ponto_pouso_l_homologacao_fk FOREIGN KEY (homologacao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_l ALTER COLUMN homologacao SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_l
	 ADD CONSTRAINT aer_pista_ponto_pouso_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_l
	 ADD CONSTRAINT aer_pista_ponto_pouso_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_l
	 ADD CONSTRAINT aer_pista_ponto_pouso_l_situacaofisica_check 
	 CHECK (situacaofisica = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.aer_pista_ponto_pouso_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.aer_pista_ponto_pouso_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipopista smallint NOT NULL,
	 revestimento smallint NOT NULL,
	 usopista smallint NOT NULL,
	 homologacao smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 largura real,
	 extensao real,
	 altitude real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT aer_pista_ponto_pouso_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX aer_pista_ponto_pouso_p_geom ON edgv.aer_pista_ponto_pouso_p USING gist (geom);

ALTER TABLE edgv.aer_pista_ponto_pouso_p OWNER TO postgres;

ALTER TABLE edgv.aer_pista_ponto_pouso_p
	 ADD CONSTRAINT aer_pista_ponto_pouso_p_tipopista_fk FOREIGN KEY (tipopista)
	 REFERENCES dominios.tipo_pista (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_p ALTER COLUMN tipopista SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_p
	 ADD CONSTRAINT aer_pista_ponto_pouso_p_revestimento_fk FOREIGN KEY (revestimento)
	 REFERENCES dominios.revestimento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_p ALTER COLUMN revestimento SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_p
	 ADD CONSTRAINT aer_pista_ponto_pouso_p_usopista_fk FOREIGN KEY (usopista)
	 REFERENCES dominios.uso_pista (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_p ALTER COLUMN usopista SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_p
	 ADD CONSTRAINT aer_pista_ponto_pouso_p_homologacao_fk FOREIGN KEY (homologacao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_p ALTER COLUMN homologacao SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_p
	 ADD CONSTRAINT aer_pista_ponto_pouso_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_p
	 ADD CONSTRAINT aer_pista_ponto_pouso_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_p
	 ADD CONSTRAINT aer_pista_ponto_pouso_p_situacaofisica_check 
	 CHECK (situacaofisica = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.aer_pista_ponto_pouso_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.aer_pista_ponto_pouso_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipopista smallint NOT NULL,
	 revestimento smallint NOT NULL,
	 usopista smallint NOT NULL,
	 homologacao smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 largura real,
	 extensao real,
	 altitude real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT aer_pista_ponto_pouso_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX aer_pista_ponto_pouso_a_geom ON edgv.aer_pista_ponto_pouso_a USING gist (geom);

ALTER TABLE edgv.aer_pista_ponto_pouso_a OWNER TO postgres;

ALTER TABLE edgv.aer_pista_ponto_pouso_a
	 ADD CONSTRAINT aer_pista_ponto_pouso_a_tipopista_fk FOREIGN KEY (tipopista)
	 REFERENCES dominios.tipo_pista (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_a ALTER COLUMN tipopista SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_a
	 ADD CONSTRAINT aer_pista_ponto_pouso_a_revestimento_fk FOREIGN KEY (revestimento)
	 REFERENCES dominios.revestimento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_a ALTER COLUMN revestimento SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_a
	 ADD CONSTRAINT aer_pista_ponto_pouso_a_usopista_fk FOREIGN KEY (usopista)
	 REFERENCES dominios.uso_pista (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_a ALTER COLUMN usopista SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_a
	 ADD CONSTRAINT aer_pista_ponto_pouso_a_homologacao_fk FOREIGN KEY (homologacao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_a ALTER COLUMN homologacao SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_a
	 ADD CONSTRAINT aer_pista_ponto_pouso_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.aer_pista_ponto_pouso_a
	 ADD CONSTRAINT aer_pista_ponto_pouso_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.aer_pista_ponto_pouso_a
	 ADD CONSTRAINT aer_pista_ponto_pouso_a_situacaofisica_check 
	 CHECK (situacaofisica = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.aer_pista_ponto_pouso_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 idtsub integer,
	 centrodecarga smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 operacional smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_subest_transm_distrib_energia_eletrica_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_subest_transm_distrib_energia_eletrica_p_geom ON edgv.enc_subest_transm_distrib_energia_eletrica_p USING gist (geom);

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p OWNER TO postgres;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p
	 ADD CONSTRAINT enc_subest_transm_distrib_energia_eletrica_p_centrodecarga_fk FOREIGN KEY (centrodecarga)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p ALTER COLUMN centrodecarga SET DEFAULT 9999;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p
	 ADD CONSTRAINT enc_subest_transm_distrib_energia_eletrica_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p
	 ADD CONSTRAINT enc_subest_transm_distrib_energia_eletrica_p_classeativecon_check 
	 CHECK (classeativecon = ANY(ARRAY[2 :: SMALLINT, 3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p
	 ADD CONSTRAINT enc_subest_transm_distrib_energia_eletrica_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_p ALTER COLUMN operacional SET DEFAULT 9999;

CREATE TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 idtsub integer,
	 centrodecarga smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 operacional smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT enc_subest_transm_distrib_energia_eletrica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_subest_transm_distrib_energia_eletrica_a_geom ON edgv.enc_subest_transm_distrib_energia_eletrica_a USING gist (geom);

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a OWNER TO postgres;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a
	 ADD CONSTRAINT enc_subest_transm_distrib_energia_eletrica_a_centrodecarga_fk FOREIGN KEY (centrodecarga)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a ALTER COLUMN centrodecarga SET DEFAULT 9999;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a
	 ADD CONSTRAINT enc_subest_transm_distrib_energia_eletrica_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a
	 ADD CONSTRAINT enc_subest_transm_distrib_energia_eletrica_a_classeativecon_check 
	 CHECK (classeativecon = ANY(ARRAY[2 :: SMALLINT, 3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a
	 ADD CONSTRAINT enc_subest_transm_distrib_energia_eletrica_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_subest_transm_distrib_energia_eletrica_a ALTER COLUMN operacional SET DEFAULT 9999;

CREATE TABLE edgv.cbge_deposito_geral_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipodepgeral smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 tipoexposicao smallint NOT NULL,
	 tipoprodutoresiduo smallint NOT NULL,
	 tipoconteudo smallint NOT NULL,
	 unidadevolume smallint NOT NULL,
	 valorvolume real,
	 tratamento smallint NOT NULL,
	 estadofisico smallint NOT NULL,
	 finalidadedep smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT cbge_deposito_geral_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_deposito_geral_p_geom ON edgv.cbge_deposito_geral_p USING gist (geom);

ALTER TABLE edgv.cbge_deposito_geral_p OWNER TO postgres;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_tipodepgeral_fk FOREIGN KEY (tipodepgeral)
	 REFERENCES dominios.tipo_dep_geral (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_tipodepgeral_check 
	 CHECK (tipodepgeral = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 8 :: SMALLINT, 9 :: SMALLINT, 10 :: SMALLINT, 11 :: SMALLINT, 19 :: SMALLINT, 26 :: SMALLINT, 32 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN tipodepgeral SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_tipoexposicao_fk FOREIGN KEY (tipoexposicao)
	 REFERENCES dominios.tipo_exposicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN tipoexposicao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_tipoprodutoresiduo_fk FOREIGN KEY (tipoprodutoresiduo)
	 REFERENCES dominios.tipo_produto_residuo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN tipoprodutoresiduo SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_tipoconteudo_fk FOREIGN KEY (tipoconteudo)
	 REFERENCES dominios.tipo_conteudo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN tipoconteudo SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_unidadevolume_fk FOREIGN KEY (unidadevolume)
	 REFERENCES dominios.unidade_volume (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN unidadevolume SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_tratamento_fk FOREIGN KEY (tratamento)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN tratamento SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_estadofisico_fk FOREIGN KEY (estadofisico)
	 REFERENCES dominios.estado_fisico (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN estadofisico SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_p
	 ADD CONSTRAINT cbge_deposito_geral_p_finalidadedep_fk FOREIGN KEY (finalidadedep)
	 REFERENCES dominios.finalidade_deposito (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_p ALTER COLUMN finalidadedep SET DEFAULT 9999;

CREATE TABLE edgv.cbge_deposito_geral_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipodepgeral smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 tipoexposicao smallint NOT NULL,
	 tipoprodutoresiduo smallint NOT NULL,
	 tipoconteudo smallint NOT NULL,
	 unidadevolume smallint NOT NULL,
	 valorvolume real,
	 tratamento smallint NOT NULL,
	 estadofisico smallint NOT NULL,
	 finalidadedep smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_deposito_geral_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_deposito_geral_a_geom ON edgv.cbge_deposito_geral_a USING gist (geom);

ALTER TABLE edgv.cbge_deposito_geral_a OWNER TO postgres;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_tipodepgeral_fk FOREIGN KEY (tipodepgeral)
	 REFERENCES dominios.tipo_dep_geral (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_tipodepgeral_check 
	 CHECK (tipodepgeral = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 8 :: SMALLINT, 9 :: SMALLINT, 10 :: SMALLINT, 11 :: SMALLINT, 19 :: SMALLINT, 26 :: SMALLINT, 32 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN tipodepgeral SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_tipoexposicao_fk FOREIGN KEY (tipoexposicao)
	 REFERENCES dominios.tipo_exposicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN tipoexposicao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_tipoprodutoresiduo_fk FOREIGN KEY (tipoprodutoresiduo)
	 REFERENCES dominios.tipo_produto_residuo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN tipoprodutoresiduo SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_tipoconteudo_fk FOREIGN KEY (tipoconteudo)
	 REFERENCES dominios.tipo_conteudo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN tipoconteudo SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_unidadevolume_fk FOREIGN KEY (unidadevolume)
	 REFERENCES dominios.unidade_volume (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN unidadevolume SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_tratamento_fk FOREIGN KEY (tratamento)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN tratamento SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_estadofisico_fk FOREIGN KEY (estadofisico)
	 REFERENCES dominios.estado_fisico (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN estadofisico SET DEFAULT 9999;

ALTER TABLE edgv.cbge_deposito_geral_a
	 ADD CONSTRAINT cbge_deposito_geral_a_finalidadedep_fk FOREIGN KEY (finalidadedep)
	 REFERENCES dominios.finalidade_deposito (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_deposito_geral_a ALTER COLUMN finalidadedep SET DEFAULT 9999;

CREATE TABLE edgv.cbge_area_agropec_ext_vegetal_pesca_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoarea smallint NOT NULL,
	 destinadoa smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_area_agropec_ext_vegetal_pesca_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_area_agropec_ext_vegetal_pesca_a_geom ON edgv.cbge_area_agropec_ext_vegetal_pesca_a USING gist (geom);

ALTER TABLE edgv.cbge_area_agropec_ext_vegetal_pesca_a OWNER TO postgres;

ALTER TABLE edgv.cbge_area_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT cbge_area_agropec_ext_vegetal_pesca_a_tipoarea_fk FOREIGN KEY (tipoarea)
	 REFERENCES dominios.tipo_area (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_area_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT cbge_area_agropec_ext_vegetal_pesca_a_tipoarea_check 
	 CHECK (tipoarea = ANY(ARRAY[4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_area_agropec_ext_vegetal_pesca_a ALTER COLUMN tipoarea SET DEFAULT 9999;

ALTER TABLE edgv.cbge_area_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT cbge_area_agropec_ext_vegetal_pesca_a_destinadoa_fk FOREIGN KEY (destinadoa)
	 REFERENCES dominios.destinado_a (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_area_agropec_ext_vegetal_pesca_a ALTER COLUMN destinadoa SET DEFAULT 9999;

CREATE TABLE edgv.cbge_canteiro_central_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT cbge_canteiro_central_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_canteiro_central_l_geom ON edgv.cbge_canteiro_central_l USING gist (geom);

ALTER TABLE edgv.cbge_canteiro_central_l OWNER TO postgres;

ALTER TABLE edgv.cbge_canteiro_central_l
	 ADD CONSTRAINT cbge_canteiro_central_l_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_canteiro_central_l ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.cbge_canteiro_central_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_canteiro_central_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_canteiro_central_a_geom ON edgv.cbge_canteiro_central_a USING gist (geom);

ALTER TABLE edgv.cbge_canteiro_central_a OWNER TO postgres;

ALTER TABLE edgv.cbge_canteiro_central_a
	 ADD CONSTRAINT cbge_canteiro_central_a_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_canteiro_central_a ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.cbge_poste_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 codident varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 matconstr smallint NOT NULL,
	 tipoposte smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT cbge_poste_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_poste_p_geom ON edgv.cbge_poste_p USING gist (geom);

ALTER TABLE edgv.cbge_poste_p OWNER TO postgres;

ALTER TABLE edgv.cbge_poste_p
	 ADD CONSTRAINT cbge_poste_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_poste_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.cbge_poste_p
	 ADD CONSTRAINT cbge_poste_p_tipoposte_fk FOREIGN KEY (tipoposte)
	 REFERENCES dominios.tipo_poste (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_poste_p ALTER COLUMN tipoposte SET DEFAULT 9999;

CREATE TABLE edgv.cbge_espelho_dagua_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 codident varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_espelho_dagua_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_espelho_dagua_a_geom ON edgv.cbge_espelho_dagua_a USING gist (geom);

ALTER TABLE edgv.cbge_espelho_dagua_a OWNER TO postgres;

CREATE TABLE edgv.cbge_entroncamento_area_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoentroncamento smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_entroncamento_area_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_entroncamento_area_a_geom ON edgv.cbge_entroncamento_area_a USING gist (geom);

ALTER TABLE edgv.cbge_entroncamento_area_a OWNER TO postgres;

ALTER TABLE edgv.cbge_entroncamento_area_a
	 ADD CONSTRAINT cbge_entroncamento_area_a_tipoentroncamento_fk FOREIGN KEY (tipoentroncamento)
	 REFERENCES dominios.tipo_entroncamento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_entroncamento_area_a ALTER COLUMN tipoentroncamento SET DEFAULT 9999;

CREATE TABLE edgv.cbge_retorno_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT cbge_retorno_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_retorno_l_geom ON edgv.cbge_retorno_l USING gist (geom);

ALTER TABLE edgv.cbge_retorno_l OWNER TO postgres;

CREATE TABLE edgv.cbge_retorno_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT cbge_retorno_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_retorno_p_geom ON edgv.cbge_retorno_p USING gist (geom);

ALTER TABLE edgv.cbge_retorno_p OWNER TO postgres;

CREATE TABLE edgv.cbge_trecho_arruamento_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 jurisdicao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 concessionaria varchar(255),
	 revestimento smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 canteirodivisorio smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 trafego smallint NOT NULL,
	 tipopavimentacao smallint NOT NULL,
	 tipovia smallint NOT NULL,
	 meiofio smallint NOT NULL,
	 sarjeta smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT cbge_trecho_arruamento_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_trecho_arruamento_l_geom ON edgv.cbge_trecho_arruamento_l USING gist (geom);

ALTER TABLE edgv.cbge_trecho_arruamento_l OWNER TO postgres;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_revestimento_fk FOREIGN KEY (revestimento)
	 REFERENCES dominios.revestimento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN revestimento SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_canteirodivisorio_fk FOREIGN KEY (canteirodivisorio)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN canteirodivisorio SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_trafego_fk FOREIGN KEY (trafego)
	 REFERENCES dominios.trafego (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN trafego SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_tipovia_fk FOREIGN KEY (tipovia)
	 REFERENCES dominios.tipo_via (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN tipovia SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_meiofio_fk FOREIGN KEY (meiofio)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN meiofio SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_l
	 ADD CONSTRAINT cbge_trecho_arruamento_l_sarjeta_fk FOREIGN KEY (sarjeta)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_l ALTER COLUMN sarjeta SET DEFAULT 9999;

CREATE TABLE edgv.cbge_trecho_arruamento_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 jurisdicao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 concessionaria varchar(255),
	 revestimento smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 canteirodivisorio smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 trafego smallint NOT NULL,
	 tipopavimentacao smallint NOT NULL,
	 tipovia smallint NOT NULL,
	 meiofio smallint NOT NULL,
	 sarjeta smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_trecho_arruamento_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_trecho_arruamento_a_geom ON edgv.cbge_trecho_arruamento_a USING gist (geom);

ALTER TABLE edgv.cbge_trecho_arruamento_a OWNER TO postgres;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_revestimento_fk FOREIGN KEY (revestimento)
	 REFERENCES dominios.revestimento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN revestimento SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_canteirodivisorio_fk FOREIGN KEY (canteirodivisorio)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN canteirodivisorio SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_trafego_fk FOREIGN KEY (trafego)
	 REFERENCES dominios.trafego (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN trafego SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_tipovia_fk FOREIGN KEY (tipovia)
	 REFERENCES dominios.tipo_via (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN tipovia SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_meiofio_fk FOREIGN KEY (meiofio)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN meiofio SET DEFAULT 9999;

ALTER TABLE edgv.cbge_trecho_arruamento_a
	 ADD CONSTRAINT cbge_trecho_arruamento_a_sarjeta_fk FOREIGN KEY (sarjeta)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_trecho_arruamento_a ALTER COLUMN sarjeta SET DEFAULT 9999;

CREATE TABLE edgv.cbge_cemiterio_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipocemiterio smallint NOT NULL,
	 denominacaoassociada smallint NOT NULL,
	 destinacaocemiterio smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT cbge_cemiterio_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_cemiterio_p_geom ON edgv.cbge_cemiterio_p USING gist (geom);

ALTER TABLE edgv.cbge_cemiterio_p OWNER TO postgres;

ALTER TABLE edgv.cbge_cemiterio_p
	 ADD CONSTRAINT cbge_cemiterio_p_tipocemiterio_fk FOREIGN KEY (tipocemiterio)
	 REFERENCES dominios.tipo_cemiterio (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_cemiterio_p ALTER COLUMN tipocemiterio SET DEFAULT 9999;

ALTER TABLE edgv.cbge_cemiterio_p
	 ADD CONSTRAINT cbge_cemiterio_p_denominacaoassociada_fk FOREIGN KEY (denominacaoassociada)
	 REFERENCES dominios.denominacao_associada (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_cemiterio_p ALTER COLUMN denominacaoassociada SET DEFAULT 9999;

ALTER TABLE edgv.cbge_cemiterio_p
	 ADD CONSTRAINT cbge_cemiterio_p_destinacaocemiterio_fk FOREIGN KEY (destinacaocemiterio)
	 REFERENCES dominios.destinacao_cemiterio (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_cemiterio_p ALTER COLUMN destinacaocemiterio SET DEFAULT 9999;

CREATE TABLE edgv.cbge_cemiterio_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipocemiterio smallint NOT NULL,
	 denominacaoassociada smallint NOT NULL,
	 destinacaocemiterio smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_cemiterio_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_cemiterio_a_geom ON edgv.cbge_cemiterio_a USING gist (geom);

ALTER TABLE edgv.cbge_cemiterio_a OWNER TO postgres;

ALTER TABLE edgv.cbge_cemiterio_a
	 ADD CONSTRAINT cbge_cemiterio_a_tipocemiterio_fk FOREIGN KEY (tipocemiterio)
	 REFERENCES dominios.tipo_cemiterio (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_cemiterio_a ALTER COLUMN tipocemiterio SET DEFAULT 9999;

ALTER TABLE edgv.cbge_cemiterio_a
	 ADD CONSTRAINT cbge_cemiterio_a_denominacaoassociada_fk FOREIGN KEY (denominacaoassociada)
	 REFERENCES dominios.denominacao_associada (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_cemiterio_a ALTER COLUMN denominacaoassociada SET DEFAULT 9999;

ALTER TABLE edgv.cbge_cemiterio_a
	 ADD CONSTRAINT cbge_cemiterio_a_destinacaocemiterio_fk FOREIGN KEY (destinacaocemiterio)
	 REFERENCES dominios.destinacao_cemiterio (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_cemiterio_a ALTER COLUMN destinacaocemiterio SET DEFAULT 9999;

CREATE TABLE edgv.cbge_delimitacao_fisica_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipodelimfis smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 eletrificada smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT cbge_delimitacao_fisica_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_delimitacao_fisica_l_geom ON edgv.cbge_delimitacao_fisica_l USING gist (geom);

ALTER TABLE edgv.cbge_delimitacao_fisica_l OWNER TO postgres;

ALTER TABLE edgv.cbge_delimitacao_fisica_l
	 ADD CONSTRAINT cbge_delimitacao_fisica_l_tipodelimfis_fk FOREIGN KEY (tipodelimfis)
	 REFERENCES dominios.tipo_delim_fis (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_delimitacao_fisica_l ALTER COLUMN tipodelimfis SET DEFAULT 9999;

ALTER TABLE edgv.cbge_delimitacao_fisica_l
	 ADD CONSTRAINT cbge_delimitacao_fisica_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_delimitacao_fisica_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.cbge_delimitacao_fisica_l
	 ADD CONSTRAINT cbge_delimitacao_fisica_l_eletrificada_fk FOREIGN KEY (eletrificada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_delimitacao_fisica_l ALTER COLUMN eletrificada SET DEFAULT 9999;

CREATE TABLE edgv.cbge_area_construida_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_area_construida_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_area_construida_a_geom ON edgv.cbge_area_construida_a USING gist (geom);

ALTER TABLE edgv.cbge_area_construida_a OWNER TO postgres;

CREATE TABLE edgv.cbge_area_habitacional_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoarea smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_area_habitacional_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_area_habitacional_a_geom ON edgv.cbge_area_habitacional_a USING gist (geom);

ALTER TABLE edgv.cbge_area_habitacional_a OWNER TO postgres;

ALTER TABLE edgv.cbge_area_habitacional_a
	 ADD CONSTRAINT cbge_area_habitacional_a_tipoarea_fk FOREIGN KEY (tipoarea)
	 REFERENCES dominios.tipo_area (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_area_habitacional_a
	 ADD CONSTRAINT cbge_area_habitacional_a_tipoarea_check 
	 CHECK (tipoarea = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_area_habitacional_a ALTER COLUMN tipoarea SET DEFAULT 9999;

CREATE TABLE edgv.cbge_assentamento_precario_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoassentamentoprecario smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_assentamento_precario_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_assentamento_precario_a_geom ON edgv.cbge_assentamento_precario_a USING gist (geom);

ALTER TABLE edgv.cbge_assentamento_precario_a OWNER TO postgres;

ALTER TABLE edgv.cbge_assentamento_precario_a
	 ADD CONSTRAINT cbge_assentamento_precario_a_tipoassentamentoprecario_fk FOREIGN KEY (tipoassentamentoprecario)
	 REFERENCES dominios.tipo_assentamento_precario (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_assentamento_precario_a ALTER COLUMN tipoassentamentoprecario SET DEFAULT 9999;

CREATE TABLE edgv.cbge_estacionamento_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 administracao smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 finalidadepatio smallint NOT NULL,
	 publico smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_estacionamento_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_estacionamento_a_geom ON edgv.cbge_estacionamento_a USING gist (geom);

ALTER TABLE edgv.cbge_estacionamento_a OWNER TO postgres;

ALTER TABLE edgv.cbge_estacionamento_a
	 ADD CONSTRAINT cbge_estacionamento_a_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_estacionamento_a
	 ADD CONSTRAINT cbge_estacionamento_a_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_estacionamento_a ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.cbge_estacionamento_a
	 ADD CONSTRAINT cbge_estacionamento_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_estacionamento_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.cbge_estacionamento_a
	 ADD CONSTRAINT cbge_estacionamento_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_estacionamento_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.cbge_estacionamento_a
	 ADD CONSTRAINT cbge_estacionamento_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_estacionamento_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.cbge_estacionamento_a
	 ADD CONSTRAINT cbge_estacionamento_a_finalidadepatio_fk FOREIGN KEY (finalidadepatio)
	 REFERENCES dominios.finalidade_patio (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_estacionamento_a
	 ADD CONSTRAINT cbge_estacionamento_a_finalidadepatio_check 
	 CHECK (finalidadepatio = ANY(ARRAY[3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_estacionamento_a ALTER COLUMN finalidadepatio SET DEFAULT 9999;

ALTER TABLE edgv.cbge_estacionamento_a
	 ADD CONSTRAINT cbge_estacionamento_a_publico_fk FOREIGN KEY (publico)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_estacionamento_a ALTER COLUMN publico SET DEFAULT 9999;

CREATE TABLE edgv.cbge_praca_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 turistica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_praca_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_praca_a_geom ON edgv.cbge_praca_a USING gist (geom);

ALTER TABLE edgv.cbge_praca_a OWNER TO postgres;

ALTER TABLE edgv.cbge_praca_a
	 ADD CONSTRAINT cbge_praca_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_praca_a ALTER COLUMN turistica SET DEFAULT 9999;

CREATE TABLE edgv.cbge_area_duto_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoarea smallint NOT NULL,
	 areavalvulas smallint NOT NULL,
	 bombeamento smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_area_duto_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_area_duto_a_geom ON edgv.cbge_area_duto_a USING gist (geom);

ALTER TABLE edgv.cbge_area_duto_a OWNER TO postgres;

ALTER TABLE edgv.cbge_area_duto_a
	 ADD CONSTRAINT cbge_area_duto_a_tipoarea_fk FOREIGN KEY (tipoarea)
	 REFERENCES dominios.tipo_area (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_area_duto_a
	 ADD CONSTRAINT cbge_area_duto_a_tipoarea_check 
	 CHECK (tipoarea = ANY(ARRAY[3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_area_duto_a ALTER COLUMN tipoarea SET DEFAULT 9999;

ALTER TABLE edgv.cbge_area_duto_a
	 ADD CONSTRAINT cbge_area_duto_a_areavalvulas_fk FOREIGN KEY (areavalvulas)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_area_duto_a ALTER COLUMN areavalvulas SET DEFAULT 9999;

ALTER TABLE edgv.cbge_area_duto_a
	 ADD CONSTRAINT cbge_area_duto_a_bombeamento_fk FOREIGN KEY (bombeamento)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_area_duto_a ALTER COLUMN bombeamento SET DEFAULT 9999;

CREATE TABLE edgv.cbge_area_de_propriedade_particular_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoarea smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_area_de_propriedade_particular_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_area_de_propriedade_particular_a_geom ON edgv.cbge_area_de_propriedade_particular_a USING gist (geom);

ALTER TABLE edgv.cbge_area_de_propriedade_particular_a OWNER TO postgres;

ALTER TABLE edgv.cbge_area_de_propriedade_particular_a
	 ADD CONSTRAINT cbge_area_de_propriedade_particular_a_tipoarea_fk FOREIGN KEY (tipoarea)
	 REFERENCES dominios.tipo_area (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_area_de_propriedade_particular_a
	 ADD CONSTRAINT cbge_area_de_propriedade_particular_a_tipoarea_check 
	 CHECK (tipoarea = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_area_de_propriedade_particular_a ALTER COLUMN tipoarea SET DEFAULT 9999;

CREATE TABLE edgv.cbge_quadra_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_quadra_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_quadra_a_geom ON edgv.cbge_quadra_a USING gist (geom);

ALTER TABLE edgv.cbge_quadra_a OWNER TO postgres;

CREATE TABLE edgv.cbge_area_uso_especifico_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoarea smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_area_uso_especifico_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_area_uso_especifico_a_geom ON edgv.cbge_area_uso_especifico_a USING gist (geom);

ALTER TABLE edgv.cbge_area_uso_especifico_a OWNER TO postgres;

ALTER TABLE edgv.cbge_area_uso_especifico_a
	 ADD CONSTRAINT cbge_area_uso_especifico_a_tipoarea_fk FOREIGN KEY (tipoarea)
	 REFERENCES dominios.tipo_area (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_area_uso_especifico_a
	 ADD CONSTRAINT cbge_area_uso_especifico_a_tipoarea_check 
	 CHECK (tipoarea = ANY(ARRAY[0 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 8 :: SMALLINT, 9 :: SMALLINT, 10 :: SMALLINT, 11 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 14 :: SMALLINT, 15 :: SMALLINT, 16 :: SMALLINT, 17 :: SMALLINT, 18 :: SMALLINT, 19 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.cbge_area_uso_especifico_a ALTER COLUMN tipoarea SET DEFAULT 9999;

CREATE TABLE edgv.cbge_passeio_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 largura real,
	 calcada smallint NOT NULL,
	 pavimentacao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT cbge_passeio_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_passeio_l_geom ON edgv.cbge_passeio_l USING gist (geom);

ALTER TABLE edgv.cbge_passeio_l OWNER TO postgres;

ALTER TABLE edgv.cbge_passeio_l
	 ADD CONSTRAINT cbge_passeio_l_calcada_fk FOREIGN KEY (calcada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_passeio_l ALTER COLUMN calcada SET DEFAULT 9999;

ALTER TABLE edgv.cbge_passeio_l
	 ADD CONSTRAINT cbge_passeio_l_pavimentacao_fk FOREIGN KEY (pavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_passeio_l ALTER COLUMN pavimentacao SET DEFAULT 9999;

CREATE TABLE edgv.cbge_passeio_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 largura real,
	 calcada smallint NOT NULL,
	 pavimentacao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_passeio_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_passeio_a_geom ON edgv.cbge_passeio_a USING gist (geom);

ALTER TABLE edgv.cbge_passeio_a OWNER TO postgres;

ALTER TABLE edgv.cbge_passeio_a
	 ADD CONSTRAINT cbge_passeio_a_calcada_fk FOREIGN KEY (calcada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_passeio_a ALTER COLUMN calcada SET DEFAULT 9999;

ALTER TABLE edgv.cbge_passeio_a
	 ADD CONSTRAINT cbge_passeio_a_pavimentacao_fk FOREIGN KEY (pavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.cbge_passeio_a ALTER COLUMN pavimentacao SET DEFAULT 9999;

CREATE TABLE edgv.cbge_largo_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT cbge_largo_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX cbge_largo_a_geom ON edgv.cbge_largo_a USING gist (geom);

ALTER TABLE edgv.cbge_largo_a OWNER TO postgres;

CREATE TABLE edgv.dut_galeria_bueiro_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipotrechoduto smallint NOT NULL,
	 mattransp smallint NOT NULL,
	 setor smallint NOT NULL,
	 posicaorelativa smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 nrdutos integer,
	 situacaoespacial smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 pesosuportmaximo real,
	 largura real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT dut_galeria_bueiro_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX dut_galeria_bueiro_l_geom ON edgv.dut_galeria_bueiro_l USING gist (geom);

ALTER TABLE edgv.dut_galeria_bueiro_l OWNER TO postgres;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_tipotrechoduto_fk FOREIGN KEY (tipotrechoduto)
	 REFERENCES dominios.tipo_trecho_duto (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_tipotrechoduto_check 
	 CHECK (tipotrechoduto = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN tipotrechoduto SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_mattransp_fk FOREIGN KEY (mattransp)
	 REFERENCES dominios.mat_transp (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN mattransp SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_setor_fk FOREIGN KEY (setor)
	 REFERENCES dominios.setor (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_setor_check 
	 CHECK (setor = ANY(ARRAY[0 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN setor SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_posicaorelativa_fk FOREIGN KEY (posicaorelativa)
	 REFERENCES dominios.posicao_relativa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN posicaorelativa SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_l
	 ADD CONSTRAINT dut_galeria_bueiro_l_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_galeria_bueiro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_l ALTER COLUMN finalidade SET DEFAULT 9999;

CREATE TABLE edgv.dut_galeria_bueiro_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipotrechoduto smallint NOT NULL,
	 mattransp smallint NOT NULL,
	 setor smallint NOT NULL,
	 posicaorelativa smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 nrdutos integer,
	 situacaoespacial smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 pesosuportmaximo real,
	 largura real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT dut_galeria_bueiro_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX dut_galeria_bueiro_p_geom ON edgv.dut_galeria_bueiro_p USING gist (geom);

ALTER TABLE edgv.dut_galeria_bueiro_p OWNER TO postgres;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_tipotrechoduto_fk FOREIGN KEY (tipotrechoduto)
	 REFERENCES dominios.tipo_trecho_duto (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_tipotrechoduto_check 
	 CHECK (tipotrechoduto = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN tipotrechoduto SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_mattransp_fk FOREIGN KEY (mattransp)
	 REFERENCES dominios.mat_transp (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN mattransp SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_setor_fk FOREIGN KEY (setor)
	 REFERENCES dominios.setor (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_setor_check 
	 CHECK (setor = ANY(ARRAY[0 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN setor SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_posicaorelativa_fk FOREIGN KEY (posicaorelativa)
	 REFERENCES dominios.posicao_relativa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN posicaorelativa SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.dut_galeria_bueiro_p
	 ADD CONSTRAINT dut_galeria_bueiro_p_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_galeria_bueiro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_galeria_bueiro_p ALTER COLUMN finalidade SET DEFAULT 9999;

CREATE TABLE edgv.dut_trecho_duto_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipotrechoduto smallint NOT NULL,
	 mattransp smallint NOT NULL,
	 setor smallint NOT NULL,
	 posicaorelativa smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 nrdutos integer,
	 situacaoespacial smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT dut_trecho_duto_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX dut_trecho_duto_l_geom ON edgv.dut_trecho_duto_l USING gist (geom);

ALTER TABLE edgv.dut_trecho_duto_l OWNER TO postgres;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_tipotrechoduto_fk FOREIGN KEY (tipotrechoduto)
	 REFERENCES dominios.tipo_trecho_duto (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_tipotrechoduto_check 
	 CHECK (tipotrechoduto = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.dut_trecho_duto_l ALTER COLUMN tipotrechoduto SET DEFAULT 9999;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_mattransp_fk FOREIGN KEY (mattransp)
	 REFERENCES dominios.mat_transp (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_trecho_duto_l ALTER COLUMN mattransp SET DEFAULT 9999;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_setor_fk FOREIGN KEY (setor)
	 REFERENCES dominios.setor (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_trecho_duto_l ALTER COLUMN setor SET DEFAULT 9999;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_posicaorelativa_fk FOREIGN KEY (posicaorelativa)
	 REFERENCES dominios.posicao_relativa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_trecho_duto_l ALTER COLUMN posicaorelativa SET DEFAULT 9999;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_trecho_duto_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_trecho_duto_l ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_trecho_duto_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.dut_trecho_duto_l
	 ADD CONSTRAINT dut_trecho_duto_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.dut_trecho_duto_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.eco_equip_agropec_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipoequipagropec smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT eco_equip_agropec_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX eco_equip_agropec_l_geom ON edgv.eco_equip_agropec_l USING gist (geom);

ALTER TABLE edgv.eco_equip_agropec_l OWNER TO postgres;

ALTER TABLE edgv.eco_equip_agropec_l
	 ADD CONSTRAINT eco_equip_agropec_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_l
	 ADD CONSTRAINT eco_equip_agropec_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_l
	 ADD CONSTRAINT eco_equip_agropec_l_tipoequipagropec_fk FOREIGN KEY (tipoequipagropec)
	 REFERENCES dominios.tipo_equip_agropec (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_l ALTER COLUMN tipoequipagropec SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_l
	 ADD CONSTRAINT eco_equip_agropec_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_l ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.eco_equip_agropec_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipoequipagropec smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT eco_equip_agropec_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX eco_equip_agropec_p_geom ON edgv.eco_equip_agropec_p USING gist (geom);

ALTER TABLE edgv.eco_equip_agropec_p OWNER TO postgres;

ALTER TABLE edgv.eco_equip_agropec_p
	 ADD CONSTRAINT eco_equip_agropec_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_p
	 ADD CONSTRAINT eco_equip_agropec_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_p
	 ADD CONSTRAINT eco_equip_agropec_p_tipoequipagropec_fk FOREIGN KEY (tipoequipagropec)
	 REFERENCES dominios.tipo_equip_agropec (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_p ALTER COLUMN tipoequipagropec SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_p
	 ADD CONSTRAINT eco_equip_agropec_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_p ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.eco_equip_agropec_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipoequipagropec smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT eco_equip_agropec_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX eco_equip_agropec_a_geom ON edgv.eco_equip_agropec_a USING gist (geom);

ALTER TABLE edgv.eco_equip_agropec_a OWNER TO postgres;

ALTER TABLE edgv.eco_equip_agropec_a
	 ADD CONSTRAINT eco_equip_agropec_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_a
	 ADD CONSTRAINT eco_equip_agropec_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_a
	 ADD CONSTRAINT eco_equip_agropec_a_tipoequipagropec_fk FOREIGN KEY (tipoequipagropec)
	 REFERENCES dominios.tipo_equip_agropec (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_a ALTER COLUMN tipoequipagropec SET DEFAULT 9999;

ALTER TABLE edgv.eco_equip_agropec_a
	 ADD CONSTRAINT eco_equip_agropec_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_equip_agropec_a ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.eco_ext_mineral_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 secaoativecon smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipoextmin smallint NOT NULL,
	 tipoproduto smallint NOT NULL,
	 tipopocomina smallint NOT NULL,
	 procextracao smallint NOT NULL,
	 formaextracao smallint NOT NULL,
	 atividade smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT eco_ext_mineral_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX eco_ext_mineral_p_geom ON edgv.eco_ext_mineral_p USING gist (geom);

ALTER TABLE edgv.eco_ext_mineral_p OWNER TO postgres;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[32 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_secaoativecon_fk FOREIGN KEY (secaoativecon)
	 REFERENCES dominios.secao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_secaoativecon_check 
	 CHECK (secaoativecon = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN secaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_tipoextmin_fk FOREIGN KEY (tipoextmin)
	 REFERENCES dominios.tipo_ext_min (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN tipoextmin SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_tipoproduto_fk FOREIGN KEY (tipoproduto)
	 REFERENCES dominios.tipo_produto_residuo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN tipoproduto SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_tipopocomina_fk FOREIGN KEY (tipopocomina)
	 REFERENCES dominios.tipo_poco_mina (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN tipopocomina SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_procextracao_fk FOREIGN KEY (procextracao)
	 REFERENCES dominios.proc_extracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN procextracao SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_formaextracao_fk FOREIGN KEY (formaextracao)
	 REFERENCES dominios.forma_extracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN formaextracao SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_p
	 ADD CONSTRAINT eco_ext_mineral_p_atividade_fk FOREIGN KEY (atividade)
	 REFERENCES dominios.atividade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_p ALTER COLUMN atividade SET DEFAULT 9999;

CREATE TABLE edgv.eco_ext_mineral_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 secaoativecon smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipoextmin smallint NOT NULL,
	 tipoproduto smallint NOT NULL,
	 tipopocomina smallint NOT NULL,
	 procextracao smallint NOT NULL,
	 formaextracao smallint NOT NULL,
	 atividade smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT eco_ext_mineral_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX eco_ext_mineral_a_geom ON edgv.eco_ext_mineral_a USING gist (geom);

ALTER TABLE edgv.eco_ext_mineral_a OWNER TO postgres;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[32 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_secaoativecon_fk FOREIGN KEY (secaoativecon)
	 REFERENCES dominios.secao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_secaoativecon_check 
	 CHECK (secaoativecon = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN secaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_tipoextmin_fk FOREIGN KEY (tipoextmin)
	 REFERENCES dominios.tipo_ext_min (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN tipoextmin SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_tipoproduto_fk FOREIGN KEY (tipoproduto)
	 REFERENCES dominios.tipo_produto_residuo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN tipoproduto SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_tipopocomina_fk FOREIGN KEY (tipopocomina)
	 REFERENCES dominios.tipo_poco_mina (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN tipopocomina SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_procextracao_fk FOREIGN KEY (procextracao)
	 REFERENCES dominios.proc_extracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN procextracao SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_formaextracao_fk FOREIGN KEY (formaextracao)
	 REFERENCES dominios.forma_extracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN formaextracao SET DEFAULT 9999;

ALTER TABLE edgv.eco_ext_mineral_a
	 ADD CONSTRAINT eco_ext_mineral_a_atividade_fk FOREIGN KEY (atividade)
	 REFERENCES dominios.atividade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_ext_mineral_a ALTER COLUMN atividade SET DEFAULT 9999;

CREATE TABLE edgv.eco_plataforma_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoplataforma smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT eco_plataforma_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX eco_plataforma_p_geom ON edgv.eco_plataforma_p USING gist (geom);

ALTER TABLE edgv.eco_plataforma_p OWNER TO postgres;

ALTER TABLE edgv.eco_plataforma_p
	 ADD CONSTRAINT eco_plataforma_p_tipoplataforma_fk FOREIGN KEY (tipoplataforma)
	 REFERENCES dominios.tipo_plataforma (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_plataforma_p ALTER COLUMN tipoplataforma SET DEFAULT 9999;

CREATE TABLE edgv.eco_plataforma_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoplataforma smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT eco_plataforma_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX eco_plataforma_a_geom ON edgv.eco_plataforma_a USING gist (geom);

ALTER TABLE edgv.eco_plataforma_a OWNER TO postgres;

ALTER TABLE edgv.eco_plataforma_a
	 ADD CONSTRAINT eco_plataforma_a_tipoplataforma_fk FOREIGN KEY (tipoplataforma)
	 REFERENCES dominios.tipo_plataforma (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.eco_plataforma_a ALTER COLUMN tipoplataforma SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_rodoviaria_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifrod smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_rodoviaria_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_rodoviaria_p_geom ON edgv.edf_edif_rodoviaria_p USING gist (geom);

ALTER TABLE edgv.edf_edif_rodoviaria_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_tipoedifrod_fk FOREIGN KEY (tipoedifrod)
	 REFERENCES dominios.tipo_edif_rod (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN tipoedifrod SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_p
	 ADD CONSTRAINT edf_edif_rodoviaria_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_rodoviaria_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifrod smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_rodoviaria_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_rodoviaria_a_geom ON edgv.edf_edif_rodoviaria_a USING gist (geom);

ALTER TABLE edgv.edf_edif_rodoviaria_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_tipoedifrod_fk FOREIGN KEY (tipoedifrod)
	 REFERENCES dominios.tipo_edif_rod (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN tipoedifrod SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_rodoviaria_a
	 ADD CONSTRAINT edf_edif_rodoviaria_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_rodoviaria_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_turistica_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifturist smallint NOT NULL,
	 ovgd smallint NOT NULL,
	 tombada smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_constr_turistica_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_turistica_p_geom ON edgv.edf_edif_constr_turistica_p USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_turistica_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_turistica_check 
	 CHECK (turistica = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_tipoedifturist_fk FOREIGN KEY (tipoedifturist)
	 REFERENCES dominios.tipo_edif_turist (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN tipoedifturist SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_ovgd_fk FOREIGN KEY (ovgd)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN ovgd SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_tombada_fk FOREIGN KEY (tombada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN tombada SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_p
	 ADD CONSTRAINT edf_edif_constr_turistica_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_turistica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifturist smallint NOT NULL,
	 ovgd smallint NOT NULL,
	 tombada smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_constr_turistica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_turistica_a_geom ON edgv.edf_edif_constr_turistica_a USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_turistica_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_turistica_check 
	 CHECK (turistica = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_tipoedifturist_fk FOREIGN KEY (tipoedifturist)
	 REFERENCES dominios.tipo_edif_turist (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN tipoedifturist SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_ovgd_fk FOREIGN KEY (ovgd)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN ovgd SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_tombada_fk FOREIGN KEY (tombada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN tombada SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_turistica_a
	 ADD CONSTRAINT edf_edif_constr_turistica_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_turistica_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_representacao_diplomatica_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tiporepdiplomatica smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_representacao_diplomatica_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_representacao_diplomatica_p_geom ON edgv.edf_representacao_diplomatica_p USING gist (geom);

ALTER TABLE edgv.edf_representacao_diplomatica_p OWNER TO postgres;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_tiporepdiplomatica_fk FOREIGN KEY (tiporepdiplomatica)
	 REFERENCES dominios.tipo_rep_diplomatica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN tiporepdiplomatica SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_p
	 ADD CONSTRAINT edf_representacao_diplomatica_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_representacao_diplomatica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tiporepdiplomatica smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_representacao_diplomatica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_representacao_diplomatica_a_geom ON edgv.edf_representacao_diplomatica_a USING gist (geom);

ALTER TABLE edgv.edf_representacao_diplomatica_a OWNER TO postgres;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_tiporepdiplomatica_fk FOREIGN KEY (tiporepdiplomatica)
	 REFERENCES dominios.tipo_rep_diplomatica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN tiporepdiplomatica SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_representacao_diplomatica_a
	 ADD CONSTRAINT edf_representacao_diplomatica_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_representacao_diplomatica_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifagropec smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_agropec_ext_vegetal_pesca_p_geom ON edgv.edf_edif_agropec_ext_vegetal_pesca_p USING gist (geom);

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_tipoedifagropec_fk FOREIGN KEY (tipoedifagropec)
	 REFERENCES dominios.tipo_edif_agropec (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN tipoedifagropec SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifagropec smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_agropec_ext_vegetal_pesca_a_geom ON edgv.edf_edif_agropec_ext_vegetal_pesca_a USING gist (geom);

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_tipoedifagropec_fk FOREIGN KEY (tipoedifagropec)
	 REFERENCES dominios.tipo_edif_agropec (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN tipoedifagropec SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a
	 ADD CONSTRAINT edf_edif_agropec_ext_vegetal_pesca_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_agropec_ext_vegetal_pesca_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_aeroportuaria_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifaero smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_constr_aeroportuaria_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_aeroportuaria_p_geom ON edgv.edf_edif_constr_aeroportuaria_p USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_tipoedifaero_fk FOREIGN KEY (tipoedifaero)
	 REFERENCES dominios.tipo_edif_aero (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN tipoedifaero SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_aeroportuaria_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifaero smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_constr_aeroportuaria_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_aeroportuaria_a_geom ON edgv.edf_edif_constr_aeroportuaria_a USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_tipoedifaero_fk FOREIGN KEY (tipoedifaero)
	 REFERENCES dominios.tipo_edif_aero (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN tipoedifaero SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a
	 ADD CONSTRAINT edf_edif_constr_aeroportuaria_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_aeroportuaria_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_banheiro_publico_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_banheiro_publico_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_banheiro_publico_p_geom ON edgv.edf_banheiro_publico_p USING gist (geom);

ALTER TABLE edgv.edf_banheiro_publico_p OWNER TO postgres;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_p
	 ADD CONSTRAINT edf_banheiro_publico_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_banheiro_publico_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_banheiro_publico_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_banheiro_publico_a_geom ON edgv.edf_banheiro_publico_a USING gist (geom);

ALTER TABLE edgv.edf_banheiro_publico_a OWNER TO postgres;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_banheiro_publico_a
	 ADD CONSTRAINT edf_banheiro_publico_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_banheiro_publico_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_metro_ferroviaria_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifmetroferrov smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_metro_ferroviaria_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_metro_ferroviaria_p_geom ON edgv.edf_edif_metro_ferroviaria_p USING gist (geom);

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_tipoedifmetroferrov_fk FOREIGN KEY (tipoedifmetroferrov)
	 REFERENCES dominios.tipo_edif_metro_ferrov (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN tipoedifmetroferrov SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_metro_ferroviaria_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifmetroferrov smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_metro_ferroviaria_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_metro_ferroviaria_a_geom ON edgv.edf_edif_metro_ferroviaria_a USING gist (geom);

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_tipoedifmetroferrov_fk FOREIGN KEY (tipoedifmetroferrov)
	 REFERENCES dominios.tipo_edif_metro_ferrov (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN tipoedifmetroferrov SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a
	 ADD CONSTRAINT edf_edif_metro_ferroviaria_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_metro_ferroviaria_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_comerc_serv_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifcomercserv smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_comerc_serv_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_comerc_serv_p_geom ON edgv.edf_edif_comerc_serv_p USING gist (geom);

ALTER TABLE edgv.edf_edif_comerc_serv_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_tipoedifcomercserv_fk FOREIGN KEY (tipoedifcomercserv)
	 REFERENCES dominios.tipo_edif_comerc_serv (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN tipoedifcomercserv SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN finalidade SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_p
	 ADD CONSTRAINT edf_edif_comerc_serv_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_comerc_serv_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifcomercserv smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_comerc_serv_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_comerc_serv_a_geom ON edgv.edf_edif_comerc_serv_a USING gist (geom);

ALTER TABLE edgv.edf_edif_comerc_serv_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_tipoedifcomercserv_fk FOREIGN KEY (tipoedifcomercserv)
	 REFERENCES dominios.tipo_edif_comerc_serv (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN tipoedifcomercserv SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN finalidade SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comerc_serv_a
	 ADD CONSTRAINT edf_edif_comerc_serv_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comerc_serv_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edificacao_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edificacao_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edificacao_p_geom ON edgv.edf_edificacao_p USING gist (geom);

ALTER TABLE edgv.edf_edificacao_p OWNER TO postgres;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_p
	 ADD CONSTRAINT edf_edificacao_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edificacao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edificacao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edificacao_a_geom ON edgv.edf_edificacao_a USING gist (geom);

ALTER TABLE edgv.edf_edificacao_a OWNER TO postgres;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edificacao_a
	 ADD CONSTRAINT edf_edificacao_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edificacao_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_saude_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 nivelatencao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_saude_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_saude_p_geom ON edgv.edf_edif_saude_p USING gist (geom);

ALTER TABLE edgv.edf_edif_saude_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_nivelatencao_fk FOREIGN KEY (nivelatencao)
	 REFERENCES dominios.nivel_atencao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN nivelatencao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_p
	 ADD CONSTRAINT edf_edif_saude_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_saude_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 nivelatencao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_saude_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_saude_a_geom ON edgv.edf_edif_saude_a USING gist (geom);

ALTER TABLE edgv.edf_edif_saude_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_nivelatencao_fk FOREIGN KEY (nivelatencao)
	 REFERENCES dominios.nivel_atencao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN nivelatencao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saude_a
	 ADD CONSTRAINT edf_edif_saude_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saude_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_guarda_municipal_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_posto_guarda_municipal_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_guarda_municipal_p_geom ON edgv.edf_posto_guarda_municipal_p USING gist (geom);

ALTER TABLE edgv.edf_posto_guarda_municipal_p OWNER TO postgres;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[1 :: SMALLINT, 5 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_p
	 ADD CONSTRAINT edf_posto_guarda_municipal_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_guarda_municipal_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_posto_guarda_municipal_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_guarda_municipal_a_geom ON edgv.edf_posto_guarda_municipal_a USING gist (geom);

ALTER TABLE edgv.edf_posto_guarda_municipal_a OWNER TO postgres;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[1 :: SMALLINT, 5 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_guarda_municipal_a
	 ADD CONSTRAINT edf_posto_guarda_municipal_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_guarda_municipal_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_abast_agua_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifabast smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_abast_agua_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_abast_agua_p_geom ON edgv.edf_edif_abast_agua_p USING gist (geom);

ALTER TABLE edgv.edf_edif_abast_agua_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_tipoedifabast_fk FOREIGN KEY (tipoedifabast)
	 REFERENCES dominios.tipo_edif_abast (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN tipoedifabast SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_p
	 ADD CONSTRAINT edf_edif_abast_agua_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_abast_agua_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifabast smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_abast_agua_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_abast_agua_a_geom ON edgv.edf_edif_abast_agua_a USING gist (geom);

ALTER TABLE edgv.edf_edif_abast_agua_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_tipoedifabast_fk FOREIGN KEY (tipoedifabast)
	 REFERENCES dominios.tipo_edif_abast (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN tipoedifabast SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_abast_agua_a
	 ADD CONSTRAINT edf_edif_abast_agua_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_abast_agua_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_fiscal_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 tipopostofisc smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_posto_fiscal_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_fiscal_p_geom ON edgv.edf_posto_fiscal_p USING gist (geom);

ALTER TABLE edgv.edf_posto_fiscal_p OWNER TO postgres;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_tipopostofisc_fk FOREIGN KEY (tipopostofisc)
	 REFERENCES dominios.tipo_posto_fisc (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN tipopostofisc SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_p
	 ADD CONSTRAINT edf_posto_fiscal_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_fiscal_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 tipopostofisc smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_posto_fiscal_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_fiscal_a_geom ON edgv.edf_posto_fiscal_a USING gist (geom);

ALTER TABLE edgv.edf_posto_fiscal_a OWNER TO postgres;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_tipopostofisc_fk FOREIGN KEY (tipopostofisc)
	 REFERENCES dominios.tipo_posto_fisc (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN tipopostofisc SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_fiscal_a
	 ADD CONSTRAINT edf_posto_fiscal_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_fiscal_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_religiosa_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifrelig smallint NOT NULL,
	 ensino smallint NOT NULL,
	 religiao varchar(255),
	 crista smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_religiosa_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_religiosa_p_geom ON edgv.edf_edif_religiosa_p USING gist (geom);

ALTER TABLE edgv.edf_edif_religiosa_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_tipoedifrelig_fk FOREIGN KEY (tipoedifrelig)
	 REFERENCES dominios.tipo_edif_relig (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN tipoedifrelig SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_ensino_fk FOREIGN KEY (ensino)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN ensino SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_crista_fk FOREIGN KEY (crista)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN crista SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_p
	 ADD CONSTRAINT edf_edif_religiosa_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_religiosa_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifrelig smallint NOT NULL,
	 ensino smallint NOT NULL,
	 religiao varchar(255),
	 crista smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_religiosa_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_religiosa_a_geom ON edgv.edf_edif_religiosa_a USING gist (geom);

ALTER TABLE edgv.edf_edif_religiosa_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_tipoedifrelig_fk FOREIGN KEY (tipoedifrelig)
	 REFERENCES dominios.tipo_edif_relig (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN tipoedifrelig SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_ensino_fk FOREIGN KEY (ensino)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN ensino SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_crista_fk FOREIGN KEY (crista)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN crista SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_religiosa_a
	 ADD CONSTRAINT edf_edif_religiosa_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_religiosa_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_ext_mineral_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_ext_mineral_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_ext_mineral_p_geom ON edgv.edf_edif_ext_mineral_p USING gist (geom);

ALTER TABLE edgv.edf_edif_ext_mineral_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_p
	 ADD CONSTRAINT edf_edif_ext_mineral_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_ext_mineral_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_ext_mineral_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_ext_mineral_a_geom ON edgv.edf_edif_ext_mineral_a USING gist (geom);

ALTER TABLE edgv.edf_edif_ext_mineral_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ext_mineral_a
	 ADD CONSTRAINT edf_edif_ext_mineral_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ext_mineral_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_est_med_fen_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_constr_est_med_fen_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_est_med_fen_p_geom ON edgv.edf_edif_constr_est_med_fen_p USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_est_med_fen_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_constr_est_med_fen_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_est_med_fen_a_geom ON edgv.edf_edif_constr_est_med_fen_a USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a
	 ADD CONSTRAINT edf_edif_constr_est_med_fen_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_est_med_fen_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_ensino_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_ensino_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_ensino_p_geom ON edgv.edf_edif_ensino_p USING gist (geom);

ALTER TABLE edgv.edf_edif_ensino_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_p
	 ADD CONSTRAINT edf_edif_ensino_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_ensino_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_ensino_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_ensino_a_geom ON edgv.edf_edif_ensino_a USING gist (geom);

ALTER TABLE edgv.edf_edif_ensino_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_ensino_a
	 ADD CONSTRAINT edf_edif_ensino_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_ensino_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_combustivel_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifcomercserv smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_posto_combustivel_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_combustivel_p_geom ON edgv.edf_posto_combustivel_p USING gist (geom);

ALTER TABLE edgv.edf_posto_combustivel_p OWNER TO postgres;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_tipoedifcomercserv_fk FOREIGN KEY (tipoedifcomercserv)
	 REFERENCES dominios.tipo_edif_comerc_serv (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_tipoedifcomercserv_check 
	 CHECK (tipoedifcomercserv = ANY(ARRAY[19 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN tipoedifcomercserv SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN finalidade SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_p
	 ADD CONSTRAINT edf_posto_combustivel_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_combustivel_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifcomercserv smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_posto_combustivel_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_combustivel_a_geom ON edgv.edf_posto_combustivel_a USING gist (geom);

ALTER TABLE edgv.edf_posto_combustivel_a OWNER TO postgres;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_tipoedifcomercserv_fk FOREIGN KEY (tipoedifcomercserv)
	 REFERENCES dominios.tipo_edif_comerc_serv (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_tipoedifcomercserv_check 
	 CHECK (tipoedifcomercserv = ANY(ARRAY[19 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN tipoedifcomercserv SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN finalidade SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_combustivel_a
	 ADD CONSTRAINT edf_posto_combustivel_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_combustivel_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_policia_militar_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoinstalmilitar smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_posto_policia_militar_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_policia_militar_p_geom ON edgv.edf_posto_policia_militar_p USING gist (geom);

ALTER TABLE edgv.edf_posto_policia_militar_p OWNER TO postgres;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[1 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_tipoinstalmilitar_fk FOREIGN KEY (tipoinstalmilitar)
	 REFERENCES dominios.tipo_instal_militar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_tipoinstalmilitar_check 
	 CHECK (tipoinstalmilitar = ANY(ARRAY[22 :: SMALLINT, 23 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN tipoinstalmilitar SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_p
	 ADD CONSTRAINT edf_posto_policia_militar_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_policia_militar_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoinstalmilitar smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_posto_policia_militar_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_policia_militar_a_geom ON edgv.edf_posto_policia_militar_a USING gist (geom);

ALTER TABLE edgv.edf_posto_policia_militar_a OWNER TO postgres;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[1 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_tipoinstalmilitar_fk FOREIGN KEY (tipoinstalmilitar)
	 REFERENCES dominios.tipo_instal_militar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_tipoinstalmilitar_check 
	 CHECK (tipoinstalmilitar = ANY(ARRAY[22 :: SMALLINT, 23 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN tipoinstalmilitar SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_militar_a
	 ADD CONSTRAINT edf_posto_policia_militar_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_militar_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_hab_indigena_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 coletiva smallint NOT NULL,
	 isolada smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_hab_indigena_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_hab_indigena_p_geom ON edgv.edf_hab_indigena_p USING gist (geom);

ALTER TABLE edgv.edf_hab_indigena_p OWNER TO postgres;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_coletiva_fk FOREIGN KEY (coletiva)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN coletiva SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_isolada_fk FOREIGN KEY (isolada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN isolada SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_p
	 ADD CONSTRAINT edf_hab_indigena_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_hab_indigena_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 coletiva smallint NOT NULL,
	 isolada smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_hab_indigena_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_hab_indigena_a_geom ON edgv.edf_hab_indigena_a USING gist (geom);

ALTER TABLE edgv.edf_hab_indigena_a OWNER TO postgres;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_coletiva_fk FOREIGN KEY (coletiva)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN coletiva SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_isolada_fk FOREIGN KEY (isolada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN isolada SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_hab_indigena_a
	 ADD CONSTRAINT edf_hab_indigena_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_hab_indigena_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_desenv_social_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 sigla varchar(255),
	 codequipdesenvsocial varchar(255),
	 localizacaoequipdesenvsocial smallint NOT NULL,
	 tipoequipdesenvsocial smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_desenv_social_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_desenv_social_p_geom ON edgv.edf_edif_desenv_social_p USING gist (geom);

ALTER TABLE edgv.edf_edif_desenv_social_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_localizacaoequipdesenvsocial_fk FOREIGN KEY (localizacaoequipdesenvsocial)
	 REFERENCES dominios.local_equip_desenv_social (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN localizacaoequipdesenvsocial SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_tipoequipdesenvsocial_fk FOREIGN KEY (tipoequipdesenvsocial)
	 REFERENCES dominios.tipo_equip_desenv_social (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN tipoequipdesenvsocial SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_p
	 ADD CONSTRAINT edf_edif_desenv_social_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_desenv_social_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 sigla varchar(255),
	 codequipdesenvsocial varchar(255),
	 localizacaoequipdesenvsocial smallint NOT NULL,
	 tipoequipdesenvsocial smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_desenv_social_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_desenv_social_a_geom ON edgv.edf_edif_desenv_social_a USING gist (geom);

ALTER TABLE edgv.edf_edif_desenv_social_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_localizacaoequipdesenvsocial_fk FOREIGN KEY (localizacaoequipdesenvsocial)
	 REFERENCES dominios.local_equip_desenv_social (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN localizacaoequipdesenvsocial SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_tipoequipdesenvsocial_fk FOREIGN KEY (tipoequipdesenvsocial)
	 REFERENCES dominios.tipo_equip_desenv_social (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN tipoequipdesenvsocial SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_desenv_social_a
	 ADD CONSTRAINT edf_edif_desenv_social_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_desenv_social_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_lazer_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoediflazer smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_constr_lazer_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_lazer_p_geom ON edgv.edf_edif_constr_lazer_p USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_lazer_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_tipoediflazer_fk FOREIGN KEY (tipoediflazer)
	 REFERENCES dominios.tipo_edif_lazer (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN tipoediflazer SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_p
	 ADD CONSTRAINT edf_edif_constr_lazer_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_lazer_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoediflazer smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_constr_lazer_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_lazer_a_geom ON edgv.edf_edif_constr_lazer_a USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_lazer_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_tipoediflazer_fk FOREIGN KEY (tipoediflazer)
	 REFERENCES dominios.tipo_edif_lazer (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN tipoediflazer SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_lazer_a
	 ADD CONSTRAINT edf_edif_constr_lazer_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_lazer_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_energia_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifenergia smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_energia_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_energia_p_geom ON edgv.edf_edif_energia_p USING gist (geom);

ALTER TABLE edgv.edf_edif_energia_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_tipoedifenergia_fk FOREIGN KEY (tipoedifenergia)
	 REFERENCES dominios.tipo_edif_energia (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN tipoedifenergia SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_p
	 ADD CONSTRAINT edf_edif_energia_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_energia_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifenergia smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_energia_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_energia_a_geom ON edgv.edf_edif_energia_a USING gist (geom);

ALTER TABLE edgv.edf_edif_energia_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_tipoedifenergia_fk FOREIGN KEY (tipoedifenergia)
	 REFERENCES dominios.tipo_edif_energia (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN tipoedifenergia SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_energia_a
	 ADD CONSTRAINT edf_edif_energia_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_energia_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_industrial_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 chamine smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_industrial_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_industrial_p_geom ON edgv.edf_edif_industrial_p USING gist (geom);

ALTER TABLE edgv.edf_edif_industrial_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_chamine_fk FOREIGN KEY (chamine)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN chamine SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_p
	 ADD CONSTRAINT edf_edif_industrial_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_industrial_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 chamine smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_industrial_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_industrial_a_geom ON edgv.edf_edif_industrial_a USING gist (geom);

ALTER TABLE edgv.edf_edif_industrial_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_chamine_fk FOREIGN KEY (chamine)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN chamine SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_industrial_a
	 ADD CONSTRAINT edf_edif_industrial_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_industrial_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_portuaria_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifport smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_constr_portuaria_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_portuaria_p_geom ON edgv.edf_edif_constr_portuaria_p USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_portuaria_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_tipoedifport_fk FOREIGN KEY (tipoedifport)
	 REFERENCES dominios.tipo_edif_port (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN tipoedifport SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_p
	 ADD CONSTRAINT edf_edif_constr_portuaria_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_constr_portuaria_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifport smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 concessionaria varchar(255),
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_constr_portuaria_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_constr_portuaria_a_geom ON edgv.edf_edif_constr_portuaria_a USING gist (geom);

ALTER TABLE edgv.edf_edif_constr_portuaria_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_tipoedifport_fk FOREIGN KEY (tipoedifport)
	 REFERENCES dominios.tipo_edif_port (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN tipoedifport SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_constr_portuaria_a
	 ADD CONSTRAINT edf_edif_constr_portuaria_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_constr_portuaria_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_comunic_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifcomunic smallint NOT NULL,
	 modalidade smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_comunic_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_comunic_p_geom ON edgv.edf_edif_comunic_p USING gist (geom);

ALTER TABLE edgv.edf_edif_comunic_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_tipoedifcomunic_fk FOREIGN KEY (tipoedifcomunic)
	 REFERENCES dominios.tipo_edif_comunic (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN tipoedifcomunic SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_modalidade_fk FOREIGN KEY (modalidade)
	 REFERENCES dominios.modalidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN modalidade SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_p
	 ADD CONSTRAINT edf_edif_comunic_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_comunic_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifcomunic smallint NOT NULL,
	 modalidade smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_comunic_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_comunic_a_geom ON edgv.edf_edif_comunic_a USING gist (geom);

ALTER TABLE edgv.edf_edif_comunic_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_tipoedifcomunic_fk FOREIGN KEY (tipoedifcomunic)
	 REFERENCES dominios.tipo_edif_comunic (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN tipoedifcomunic SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_modalidade_fk FOREIGN KEY (modalidade)
	 REFERENCES dominios.modalidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN modalidade SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_comunic_a
	 ADD CONSTRAINT edf_edif_comunic_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_comunic_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_policia_rod_federal_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_posto_policia_rod_federal_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_policia_rod_federal_p_geom ON edgv.edf_posto_policia_rod_federal_p USING gist (geom);

ALTER TABLE edgv.edf_posto_policia_rod_federal_p OWNER TO postgres;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[1 :: SMALLINT, 2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p
	 ADD CONSTRAINT edf_posto_policia_rod_federal_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_posto_policia_rod_federal_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_posto_policia_rod_federal_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_posto_policia_rod_federal_a_geom ON edgv.edf_posto_policia_rod_federal_a USING gist (geom);

ALTER TABLE edgv.edf_posto_policia_rod_federal_a OWNER TO postgres;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[1 :: SMALLINT, 2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a
	 ADD CONSTRAINT edf_posto_policia_rod_federal_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_posto_policia_rod_federal_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_pub_civil_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_pub_civil_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_pub_civil_p_geom ON edgv.edf_edif_pub_civil_p USING gist (geom);

ALTER TABLE edgv.edf_edif_pub_civil_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[0 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 8 :: SMALLINT, 9 :: SMALLINT, 10 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 14 :: SMALLINT, 15 :: SMALLINT, 16 :: SMALLINT, 22 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_p
	 ADD CONSTRAINT edf_edif_pub_civil_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_pub_civil_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_pub_civil_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_pub_civil_a_geom ON edgv.edf_edif_pub_civil_a USING gist (geom);

ALTER TABLE edgv.edf_edif_pub_civil_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[0 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 8 :: SMALLINT, 9 :: SMALLINT, 10 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 14 :: SMALLINT, 15 :: SMALLINT, 16 :: SMALLINT, 22 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_civil_a
	 ADD CONSTRAINT edf_edif_pub_civil_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_civil_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_saneamento_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifsaneam smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_saneamento_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_saneamento_p_geom ON edgv.edf_edif_saneamento_p USING gist (geom);

ALTER TABLE edgv.edf_edif_saneamento_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_tipoedifsaneam_fk FOREIGN KEY (tipoedifsaneam)
	 REFERENCES dominios.tipo_edif_saneam (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN tipoedifsaneam SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_p
	 ADD CONSTRAINT edf_edif_saneamento_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_saneamento_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipoedifsaneam smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_saneamento_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_saneamento_a_geom ON edgv.edf_edif_saneamento_a USING gist (geom);

ALTER TABLE edgv.edf_edif_saneamento_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_tipoedifsaneam_fk FOREIGN KEY (tipoedifsaneam)
	 REFERENCES dominios.tipo_edif_saneam (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN tipoedifsaneam SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_saneamento_a
	 ADD CONSTRAINT edf_edif_saneamento_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_saneamento_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_policia_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_policia_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_policia_p_geom ON edgv.edf_edif_policia_p USING gist (geom);

ALTER TABLE edgv.edf_edif_policia_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[1 :: SMALLINT, 2 :: SMALLINT, 11 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_p
	 ADD CONSTRAINT edf_edif_policia_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_policia_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoedifpubcivil smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_policia_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_policia_a_geom ON edgv.edf_edif_policia_a USING gist (geom);

ALTER TABLE edgv.edf_edif_policia_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_tipoedifpubcivil_fk FOREIGN KEY (tipoedifpubcivil)
	 REFERENCES dominios.tipo_org_civil (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_tipoedifpubcivil_check 
	 CHECK (tipoedifpubcivil = ANY(ARRAY[1 :: SMALLINT, 2 :: SMALLINT, 11 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN tipoedifpubcivil SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_policia_a
	 ADD CONSTRAINT edf_edif_policia_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_policia_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_pub_militar_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoinstalmilitar smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_pub_militar_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_pub_militar_p_geom ON edgv.edf_edif_pub_militar_p USING gist (geom);

ALTER TABLE edgv.edf_edif_pub_militar_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_tipoinstalmilitar_fk FOREIGN KEY (tipoinstalmilitar)
	 REFERENCES dominios.tipo_instal_militar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN tipoinstalmilitar SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_p
	 ADD CONSTRAINT edf_edif_pub_militar_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_pub_militar_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 tipousoedif smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 tipoinstalmilitar smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_pub_militar_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_pub_militar_a_geom ON edgv.edf_edif_pub_militar_a USING gist (geom);

ALTER TABLE edgv.edf_edif_pub_militar_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_tipousoedif_fk FOREIGN KEY (tipousoedif)
	 REFERENCES dominios.tipo_uso_edif (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_tipousoedif_check 
	 CHECK (tipousoedif = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 6 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN tipousoedif SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_tipoinstalmilitar_fk FOREIGN KEY (tipoinstalmilitar)
	 REFERENCES dominios.tipo_instal_militar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN tipoinstalmilitar SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_pub_militar_a
	 ADD CONSTRAINT edf_edif_pub_militar_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_pub_militar_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_residencial_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT edf_edif_residencial_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_residencial_p_geom ON edgv.edf_edif_residencial_p USING gist (geom);

ALTER TABLE edgv.edf_edif_residencial_p OWNER TO postgres;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_p
	 ADD CONSTRAINT edf_edif_residencial_p_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_p ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.edf_edif_residencial_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 alturaaproximada real,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 administracao smallint NOT NULL,
	 classeativecon smallint NOT NULL,
	 divisaoativecon smallint NOT NULL,
	 grupoativecon smallint NOT NULL,
	 proprioadm smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT edf_edif_residencial_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX edf_edif_residencial_a_geom ON edgv.edf_edif_residencial_a USING gist (geom);

ALTER TABLE edgv.edf_edif_residencial_a OWNER TO postgres;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN cultura SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_classeativecon_fk FOREIGN KEY (classeativecon)
	 REFERENCES dominios.classe_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN classeativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_divisaoativecon_fk FOREIGN KEY (divisaoativecon)
	 REFERENCES dominios.divisao_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN divisaoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_grupoativecon_fk FOREIGN KEY (grupoativecon)
	 REFERENCES dominios.grupo_ativ_econ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN grupoativecon SET DEFAULT 9999;

ALTER TABLE edgv.edf_edif_residencial_a
	 ADD CONSTRAINT edf_edif_residencial_a_proprioadm_fk FOREIGN KEY (proprioadm)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.edf_edif_residencial_a ALTER COLUMN proprioadm SET DEFAULT 9999;

CREATE TABLE edgv.emu_acesso_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT emu_acesso_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_acesso_l_geom ON edgv.emu_acesso_l USING gist (geom);

ALTER TABLE edgv.emu_acesso_l OWNER TO postgres;

ALTER TABLE edgv.emu_acesso_l
	 ADD CONSTRAINT emu_acesso_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_l
	 ADD CONSTRAINT emu_acesso_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_l
	 ADD CONSTRAINT emu_acesso_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_l
	 ADD CONSTRAINT emu_acesso_l_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_l ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_acesso_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT emu_acesso_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_acesso_p_geom ON edgv.emu_acesso_p USING gist (geom);

ALTER TABLE edgv.emu_acesso_p OWNER TO postgres;

ALTER TABLE edgv.emu_acesso_p
	 ADD CONSTRAINT emu_acesso_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_p
	 ADD CONSTRAINT emu_acesso_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_p
	 ADD CONSTRAINT emu_acesso_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_p
	 ADD CONSTRAINT emu_acesso_p_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_p ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_acesso_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT emu_acesso_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_acesso_a_geom ON edgv.emu_acesso_a USING gist (geom);

ALTER TABLE edgv.emu_acesso_a OWNER TO postgres;

ALTER TABLE edgv.emu_acesso_a
	 ADD CONSTRAINT emu_acesso_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_a
	 ADD CONSTRAINT emu_acesso_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_a
	 ADD CONSTRAINT emu_acesso_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_acesso_a
	 ADD CONSTRAINT emu_acesso_a_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_acesso_a ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_rampa_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT emu_rampa_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_rampa_l_geom ON edgv.emu_rampa_l USING gist (geom);

ALTER TABLE edgv.emu_rampa_l OWNER TO postgres;

ALTER TABLE edgv.emu_rampa_l
	 ADD CONSTRAINT emu_rampa_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_l
	 ADD CONSTRAINT emu_rampa_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_l
	 ADD CONSTRAINT emu_rampa_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_l
	 ADD CONSTRAINT emu_rampa_l_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_l ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_rampa_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT emu_rampa_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_rampa_p_geom ON edgv.emu_rampa_p USING gist (geom);

ALTER TABLE edgv.emu_rampa_p OWNER TO postgres;

ALTER TABLE edgv.emu_rampa_p
	 ADD CONSTRAINT emu_rampa_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_p
	 ADD CONSTRAINT emu_rampa_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_p
	 ADD CONSTRAINT emu_rampa_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_p
	 ADD CONSTRAINT emu_rampa_p_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_p ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_rampa_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT emu_rampa_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_rampa_a_geom ON edgv.emu_rampa_a USING gist (geom);

ALTER TABLE edgv.emu_rampa_a OWNER TO postgres;

ALTER TABLE edgv.emu_rampa_a
	 ADD CONSTRAINT emu_rampa_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_a
	 ADD CONSTRAINT emu_rampa_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_a
	 ADD CONSTRAINT emu_rampa_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_rampa_a
	 ADD CONSTRAINT emu_rampa_a_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_rampa_a ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_ciclovia_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 revestimento smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT emu_ciclovia_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_ciclovia_l_geom ON edgv.emu_ciclovia_l USING gist (geom);

ALTER TABLE edgv.emu_ciclovia_l OWNER TO postgres;

ALTER TABLE edgv.emu_ciclovia_l
	 ADD CONSTRAINT emu_ciclovia_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_ciclovia_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_ciclovia_l
	 ADD CONSTRAINT emu_ciclovia_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_ciclovia_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_ciclovia_l
	 ADD CONSTRAINT emu_ciclovia_l_revestimento_fk FOREIGN KEY (revestimento)
	 REFERENCES dominios.revestimento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_ciclovia_l ALTER COLUMN revestimento SET DEFAULT 9999;

CREATE TABLE edgv.emu_elevador_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 tipoelevador smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT emu_elevador_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_elevador_l_geom ON edgv.emu_elevador_l USING gist (geom);

ALTER TABLE edgv.emu_elevador_l OWNER TO postgres;

ALTER TABLE edgv.emu_elevador_l
	 ADD CONSTRAINT emu_elevador_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_l
	 ADD CONSTRAINT emu_elevador_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_l
	 ADD CONSTRAINT emu_elevador_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_l
	 ADD CONSTRAINT emu_elevador_l_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_l ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_l
	 ADD CONSTRAINT emu_elevador_l_tipoelevador_fk FOREIGN KEY (tipoelevador)
	 REFERENCES dominios.tipo_elevador (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_l ALTER COLUMN tipoelevador SET DEFAULT 9999;

CREATE TABLE edgv.emu_elevador_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 tipoelevador smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT emu_elevador_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_elevador_p_geom ON edgv.emu_elevador_p USING gist (geom);

ALTER TABLE edgv.emu_elevador_p OWNER TO postgres;

ALTER TABLE edgv.emu_elevador_p
	 ADD CONSTRAINT emu_elevador_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_p
	 ADD CONSTRAINT emu_elevador_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_p
	 ADD CONSTRAINT emu_elevador_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_p
	 ADD CONSTRAINT emu_elevador_p_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_p ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_p
	 ADD CONSTRAINT emu_elevador_p_tipoelevador_fk FOREIGN KEY (tipoelevador)
	 REFERENCES dominios.tipo_elevador (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_p ALTER COLUMN tipoelevador SET DEFAULT 9999;

CREATE TABLE edgv.emu_elevador_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 tipoelevador smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT emu_elevador_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_elevador_a_geom ON edgv.emu_elevador_a USING gist (geom);

ALTER TABLE edgv.emu_elevador_a OWNER TO postgres;

ALTER TABLE edgv.emu_elevador_a
	 ADD CONSTRAINT emu_elevador_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_a
	 ADD CONSTRAINT emu_elevador_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_a
	 ADD CONSTRAINT emu_elevador_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_a
	 ADD CONSTRAINT emu_elevador_a_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_a ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.emu_elevador_a
	 ADD CONSTRAINT emu_elevador_a_tipoelevador_fk FOREIGN KEY (tipoelevador)
	 REFERENCES dominios.tipo_elevador (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_elevador_a ALTER COLUMN tipoelevador SET DEFAULT 9999;

CREATE TABLE edgv.emu_escadaria_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT emu_escadaria_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_escadaria_l_geom ON edgv.emu_escadaria_l USING gist (geom);

ALTER TABLE edgv.emu_escadaria_l OWNER TO postgres;

ALTER TABLE edgv.emu_escadaria_l
	 ADD CONSTRAINT emu_escadaria_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_l
	 ADD CONSTRAINT emu_escadaria_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_l
	 ADD CONSTRAINT emu_escadaria_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_l
	 ADD CONSTRAINT emu_escadaria_l_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_l ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_escadaria_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT emu_escadaria_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_escadaria_p_geom ON edgv.emu_escadaria_p USING gist (geom);

ALTER TABLE edgv.emu_escadaria_p OWNER TO postgres;

ALTER TABLE edgv.emu_escadaria_p
	 ADD CONSTRAINT emu_escadaria_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_p
	 ADD CONSTRAINT emu_escadaria_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_p
	 ADD CONSTRAINT emu_escadaria_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_p
	 ADD CONSTRAINT emu_escadaria_p_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_p ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_escadaria_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT emu_escadaria_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_escadaria_a_geom ON edgv.emu_escadaria_a USING gist (geom);

ALTER TABLE edgv.emu_escadaria_a OWNER TO postgres;

ALTER TABLE edgv.emu_escadaria_a
	 ADD CONSTRAINT emu_escadaria_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_a
	 ADD CONSTRAINT emu_escadaria_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_a
	 ADD CONSTRAINT emu_escadaria_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_escadaria_a
	 ADD CONSTRAINT emu_escadaria_a_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_escadaria_a ALTER COLUMN situacaoespacial SET DEFAULT 9999;

CREATE TABLE edgv.emu_poste_sinalizacao_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 codident varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 matconstr smallint NOT NULL,
	 tipoposte smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT emu_poste_sinalizacao_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX emu_poste_sinalizacao_p_geom ON edgv.emu_poste_sinalizacao_p USING gist (geom);

ALTER TABLE edgv.emu_poste_sinalizacao_p OWNER TO postgres;

ALTER TABLE edgv.emu_poste_sinalizacao_p
	 ADD CONSTRAINT emu_poste_sinalizacao_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_poste_sinalizacao_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.emu_poste_sinalizacao_p
	 ADD CONSTRAINT emu_poste_sinalizacao_p_tipoposte_fk FOREIGN KEY (tipoposte)
	 REFERENCES dominios.tipo_poste (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.emu_poste_sinalizacao_p
	 ADD CONSTRAINT emu_poste_sinalizacao_p_tipoposte_check 
	 CHECK (tipoposte = ANY(ARRAY[5 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.emu_poste_sinalizacao_p ALTER COLUMN tipoposte SET DEFAULT 9999;

CREATE TABLE edgv.enc_casa_de_forca_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_casa_de_forca_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_casa_de_forca_p_geom ON edgv.enc_casa_de_forca_p USING gist (geom);

ALTER TABLE edgv.enc_casa_de_forca_p OWNER TO postgres;

CREATE TABLE edgv.enc_torre_energia_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 ovgd smallint NOT NULL,
	 alturaestimada real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_torre_energia_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_torre_energia_p_geom ON edgv.enc_torre_energia_p USING gist (geom);

ALTER TABLE edgv.enc_torre_energia_p OWNER TO postgres;

ALTER TABLE edgv.enc_torre_energia_p
	 ADD CONSTRAINT enc_torre_energia_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_torre_energia_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_torre_energia_p
	 ADD CONSTRAINT enc_torre_energia_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_torre_energia_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_torre_energia_p
	 ADD CONSTRAINT enc_torre_energia_p_ovgd_fk FOREIGN KEY (ovgd)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_torre_energia_p ALTER COLUMN ovgd SET DEFAULT 9999;

CREATE TABLE edgv.enc_trecho_energia_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 especie smallint NOT NULL,
	 posicaorelativa smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 largurafaixaservidao real,
	 sin smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT enc_trecho_energia_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_trecho_energia_l_geom ON edgv.enc_trecho_energia_l USING gist (geom);

ALTER TABLE edgv.enc_trecho_energia_l OWNER TO postgres;

ALTER TABLE edgv.enc_trecho_energia_l
	 ADD CONSTRAINT enc_trecho_energia_l_especie_fk FOREIGN KEY (especie)
	 REFERENCES dominios.especie_trecho_energia (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_energia_l ALTER COLUMN especie SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_energia_l
	 ADD CONSTRAINT enc_trecho_energia_l_posicaorelativa_fk FOREIGN KEY (posicaorelativa)
	 REFERENCES dominios.posicao_relativa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_energia_l ALTER COLUMN posicaorelativa SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_energia_l
	 ADD CONSTRAINT enc_trecho_energia_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_energia_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_energia_l
	 ADD CONSTRAINT enc_trecho_energia_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_energia_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_energia_l
	 ADD CONSTRAINT enc_trecho_energia_l_sin_fk FOREIGN KEY (sin)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_energia_l ALTER COLUMN sin SET DEFAULT 9999;

CREATE TABLE edgv.enc_grupo_transformadores_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_grupo_transformadores_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_grupo_transformadores_p_geom ON edgv.enc_grupo_transformadores_p USING gist (geom);

ALTER TABLE edgv.enc_grupo_transformadores_p OWNER TO postgres;

CREATE TABLE edgv.enc_grupo_transformadores_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT enc_grupo_transformadores_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_grupo_transformadores_a_geom ON edgv.enc_grupo_transformadores_a USING gist (geom);

ALTER TABLE edgv.enc_grupo_transformadores_a OWNER TO postgres;

CREATE TABLE edgv.enc_est_gerad_energia_eletrica_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_est_gerad_energia_eletrica_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_est_gerad_energia_eletrica_p_geom ON edgv.enc_est_gerad_energia_eletrica_p USING gist (geom);

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_p OWNER TO postgres;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_p
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_p_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_p
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_p_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[0 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_p ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_p
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_p
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.enc_est_gerad_energia_eletrica_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT enc_est_gerad_energia_eletrica_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_est_gerad_energia_eletrica_l_geom ON edgv.enc_est_gerad_energia_eletrica_l USING gist (geom);

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_l OWNER TO postgres;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_l
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_l_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_l
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_l_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[0 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_l ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_l
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_l
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.enc_est_gerad_energia_eletrica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT enc_est_gerad_energia_eletrica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_est_gerad_energia_eletrica_a_geom ON edgv.enc_est_gerad_energia_eletrica_a USING gist (geom);

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_a OWNER TO postgres;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_a
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_a_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_a
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_a_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[0 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_a ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_a
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_a
	 ADD CONSTRAINT enc_est_gerad_energia_eletrica_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_est_gerad_energia_eletrica_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.enc_central_geradora_eolica_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_central_geradora_eolica_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_central_geradora_eolica_p_geom ON edgv.enc_central_geradora_eolica_p USING gist (geom);

ALTER TABLE edgv.enc_central_geradora_eolica_p OWNER TO postgres;

ALTER TABLE edgv.enc_central_geradora_eolica_p
	 ADD CONSTRAINT enc_central_geradora_eolica_p_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_p
	 ADD CONSTRAINT enc_central_geradora_eolica_p_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[5 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_central_geradora_eolica_p ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_central_geradora_eolica_p
	 ADD CONSTRAINT enc_central_geradora_eolica_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_central_geradora_eolica_p
	 ADD CONSTRAINT enc_central_geradora_eolica_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.enc_central_geradora_eolica_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT enc_central_geradora_eolica_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_central_geradora_eolica_l_geom ON edgv.enc_central_geradora_eolica_l USING gist (geom);

ALTER TABLE edgv.enc_central_geradora_eolica_l OWNER TO postgres;

ALTER TABLE edgv.enc_central_geradora_eolica_l
	 ADD CONSTRAINT enc_central_geradora_eolica_l_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_l
	 ADD CONSTRAINT enc_central_geradora_eolica_l_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[5 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_central_geradora_eolica_l ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_central_geradora_eolica_l
	 ADD CONSTRAINT enc_central_geradora_eolica_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_central_geradora_eolica_l
	 ADD CONSTRAINT enc_central_geradora_eolica_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.enc_central_geradora_eolica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT enc_central_geradora_eolica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_central_geradora_eolica_a_geom ON edgv.enc_central_geradora_eolica_a USING gist (geom);

ALTER TABLE edgv.enc_central_geradora_eolica_a OWNER TO postgres;

ALTER TABLE edgv.enc_central_geradora_eolica_a
	 ADD CONSTRAINT enc_central_geradora_eolica_a_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_a
	 ADD CONSTRAINT enc_central_geradora_eolica_a_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[5 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_central_geradora_eolica_a ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_central_geradora_eolica_a
	 ADD CONSTRAINT enc_central_geradora_eolica_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_central_geradora_eolica_a
	 ADD CONSTRAINT enc_central_geradora_eolica_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_central_geradora_eolica_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.enc_aerogerador_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 alturatorreaer real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_aerogerador_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_aerogerador_p_geom ON edgv.enc_aerogerador_p USING gist (geom);

ALTER TABLE edgv.enc_aerogerador_p OWNER TO postgres;

CREATE TABLE edgv.enc_hidreletrica_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 tipoahe smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT enc_hidreletrica_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_hidreletrica_l_geom ON edgv.enc_hidreletrica_l USING gist (geom);

ALTER TABLE edgv.enc_hidreletrica_l OWNER TO postgres;

ALTER TABLE edgv.enc_hidreletrica_l
	 ADD CONSTRAINT enc_hidreletrica_l_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_l
	 ADD CONSTRAINT enc_hidreletrica_l_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[8 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_hidreletrica_l ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_l
	 ADD CONSTRAINT enc_hidreletrica_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_l
	 ADD CONSTRAINT enc_hidreletrica_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_l
	 ADD CONSTRAINT enc_hidreletrica_l_tipoahe_fk FOREIGN KEY (tipoahe)
	 REFERENCES dominios.tipo_ahe (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_l ALTER COLUMN tipoahe SET DEFAULT 9999;

CREATE TABLE edgv.enc_hidreletrica_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 tipoahe smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_hidreletrica_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_hidreletrica_p_geom ON edgv.enc_hidreletrica_p USING gist (geom);

ALTER TABLE edgv.enc_hidreletrica_p OWNER TO postgres;

ALTER TABLE edgv.enc_hidreletrica_p
	 ADD CONSTRAINT enc_hidreletrica_p_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_p
	 ADD CONSTRAINT enc_hidreletrica_p_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[8 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_hidreletrica_p ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_p
	 ADD CONSTRAINT enc_hidreletrica_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_p
	 ADD CONSTRAINT enc_hidreletrica_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_p
	 ADD CONSTRAINT enc_hidreletrica_p_tipoahe_fk FOREIGN KEY (tipoahe)
	 REFERENCES dominios.tipo_ahe (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_p ALTER COLUMN tipoahe SET DEFAULT 9999;

CREATE TABLE edgv.enc_hidreletrica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 tipoahe smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT enc_hidreletrica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_hidreletrica_a_geom ON edgv.enc_hidreletrica_a USING gist (geom);

ALTER TABLE edgv.enc_hidreletrica_a OWNER TO postgres;

ALTER TABLE edgv.enc_hidreletrica_a
	 ADD CONSTRAINT enc_hidreletrica_a_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_a
	 ADD CONSTRAINT enc_hidreletrica_a_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[8 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_hidreletrica_a ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_a
	 ADD CONSTRAINT enc_hidreletrica_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_a
	 ADD CONSTRAINT enc_hidreletrica_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_hidreletrica_a
	 ADD CONSTRAINT enc_hidreletrica_a_tipoahe_fk FOREIGN KEY (tipoahe)
	 REFERENCES dominios.tipo_ahe (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_hidreletrica_a ALTER COLUMN tipoahe SET DEFAULT 9999;

CREATE TABLE edgv.enc_antena_comunic_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 posicaoreledific smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_antena_comunic_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_antena_comunic_p_geom ON edgv.enc_antena_comunic_p USING gist (geom);

ALTER TABLE edgv.enc_antena_comunic_p OWNER TO postgres;

ALTER TABLE edgv.enc_antena_comunic_p
	 ADD CONSTRAINT enc_antena_comunic_p_posicaoreledific_fk FOREIGN KEY (posicaoreledific)
	 REFERENCES dominios.posicao_rel_edific (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_antena_comunic_p ALTER COLUMN posicaoreledific SET DEFAULT 9999;

CREATE TABLE edgv.enc_termeletrica_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 tipocombustivel smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_termeletrica_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_termeletrica_p_geom ON edgv.enc_termeletrica_p USING gist (geom);

ALTER TABLE edgv.enc_termeletrica_p OWNER TO postgres;

ALTER TABLE edgv.enc_termeletrica_p
	 ADD CONSTRAINT enc_termeletrica_p_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_termeletrica_p
	 ADD CONSTRAINT enc_termeletrica_p_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_termeletrica_p ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_termeletrica_p
	 ADD CONSTRAINT enc_termeletrica_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_termeletrica_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_termeletrica_p
	 ADD CONSTRAINT enc_termeletrica_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_termeletrica_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_termeletrica_p
	 ADD CONSTRAINT enc_termeletrica_p_tipocombustivel_fk FOREIGN KEY (tipocombustivel)
	 REFERENCES dominios.tipo_combustivel (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_termeletrica_p ALTER COLUMN tipocombustivel SET DEFAULT 9999;

CREATE TABLE edgv.enc_termeletrica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 ceg varchar(16),
	 tipoestgerad smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 potenciaout real,
	 tipocombustivel smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT enc_termeletrica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_termeletrica_a_geom ON edgv.enc_termeletrica_a USING gist (geom);

ALTER TABLE edgv.enc_termeletrica_a OWNER TO postgres;

ALTER TABLE edgv.enc_termeletrica_a
	 ADD CONSTRAINT enc_termeletrica_a_tipoestgerad_fk FOREIGN KEY (tipoestgerad)
	 REFERENCES dominios.tipo_est_gerad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_termeletrica_a
	 ADD CONSTRAINT enc_termeletrica_a_tipoestgerad_check 
	 CHECK (tipoestgerad = ANY(ARRAY[9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.enc_termeletrica_a ALTER COLUMN tipoestgerad SET DEFAULT 9999;

ALTER TABLE edgv.enc_termeletrica_a
	 ADD CONSTRAINT enc_termeletrica_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_termeletrica_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_termeletrica_a
	 ADD CONSTRAINT enc_termeletrica_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_termeletrica_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_termeletrica_a
	 ADD CONSTRAINT enc_termeletrica_a_tipocombustivel_fk FOREIGN KEY (tipocombustivel)
	 REFERENCES dominios.tipo_combustivel (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_termeletrica_a ALTER COLUMN tipocombustivel SET DEFAULT 9999;

CREATE TABLE edgv.enc_trecho_comunic_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipotrechocomunic smallint NOT NULL,
	 posicaorelativa smallint NOT NULL,
	 matcondutor smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 emduto smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT enc_trecho_comunic_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_trecho_comunic_l_geom ON edgv.enc_trecho_comunic_l USING gist (geom);

ALTER TABLE edgv.enc_trecho_comunic_l OWNER TO postgres;

ALTER TABLE edgv.enc_trecho_comunic_l
	 ADD CONSTRAINT enc_trecho_comunic_l_tipotrechocomunic_fk FOREIGN KEY (tipotrechocomunic)
	 REFERENCES dominios.tipo_trecho_comunic (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_comunic_l ALTER COLUMN tipotrechocomunic SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_comunic_l
	 ADD CONSTRAINT enc_trecho_comunic_l_posicaorelativa_fk FOREIGN KEY (posicaorelativa)
	 REFERENCES dominios.posicao_relativa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_comunic_l ALTER COLUMN posicaorelativa SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_comunic_l
	 ADD CONSTRAINT enc_trecho_comunic_l_matcondutor_fk FOREIGN KEY (matcondutor)
	 REFERENCES dominios.mat_condutor (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_comunic_l ALTER COLUMN matcondutor SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_comunic_l
	 ADD CONSTRAINT enc_trecho_comunic_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_comunic_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_comunic_l
	 ADD CONSTRAINT enc_trecho_comunic_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_comunic_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_trecho_comunic_l
	 ADD CONSTRAINT enc_trecho_comunic_l_emduto_fk FOREIGN KEY (emduto)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_trecho_comunic_l ALTER COLUMN emduto SET DEFAULT 9999;

CREATE TABLE edgv.enc_torre_comunic_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 posicaoreledific smallint NOT NULL,
	 ovgd smallint NOT NULL,
	 alturaestimada real,
	 modalidade smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT enc_torre_comunic_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_torre_comunic_p_geom ON edgv.enc_torre_comunic_p USING gist (geom);

ALTER TABLE edgv.enc_torre_comunic_p OWNER TO postgres;

ALTER TABLE edgv.enc_torre_comunic_p
	 ADD CONSTRAINT enc_torre_comunic_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_torre_comunic_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.enc_torre_comunic_p
	 ADD CONSTRAINT enc_torre_comunic_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_torre_comunic_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.enc_torre_comunic_p
	 ADD CONSTRAINT enc_torre_comunic_p_posicaoreledific_fk FOREIGN KEY (posicaoreledific)
	 REFERENCES dominios.posicao_rel_edific (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_torre_comunic_p ALTER COLUMN posicaoreledific SET DEFAULT 9999;

ALTER TABLE edgv.enc_torre_comunic_p
	 ADD CONSTRAINT enc_torre_comunic_p_ovgd_fk FOREIGN KEY (ovgd)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_torre_comunic_p ALTER COLUMN ovgd SET DEFAULT 9999;

ALTER TABLE edgv.enc_torre_comunic_p
	 ADD CONSTRAINT enc_torre_comunic_p_modalidade_fk FOREIGN KEY (modalidade)
	 REFERENCES dominios.modalidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.enc_torre_comunic_p ALTER COLUMN modalidade SET DEFAULT 9999;

CREATE TABLE edgv.enc_zona_linhas_energia_comunicacao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT enc_zona_linhas_energia_comunicacao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX enc_zona_linhas_energia_comunicacao_a_geom ON edgv.enc_zona_linhas_energia_comunicacao_a USING gist (geom);

ALTER TABLE edgv.enc_zona_linhas_energia_comunicacao_a OWNER TO postgres;

CREATE TABLE edgv.fer_girador_ferroviario_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 administracao smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT fer_girador_ferroviario_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX fer_girador_ferroviario_p_geom ON edgv.fer_girador_ferroviario_p USING gist (geom);

ALTER TABLE edgv.fer_girador_ferroviario_p OWNER TO postgres;

ALTER TABLE edgv.fer_girador_ferroviario_p
	 ADD CONSTRAINT fer_girador_ferroviario_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_girador_ferroviario_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.fer_girador_ferroviario_p
	 ADD CONSTRAINT fer_girador_ferroviario_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_girador_ferroviario_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.fer_girador_ferroviario_p
	 ADD CONSTRAINT fer_girador_ferroviario_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_girador_ferroviario_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.fer_trecho_ferroviario_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 codtrechoferrov varchar(25),
	 posicaorelativa smallint NOT NULL,
	 tipotrechoferrov smallint NOT NULL,
	 bitola smallint NOT NULL,
	 eletrificada smallint NOT NULL,
	 nrlinhas smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 concessionaria varchar(255),
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 cargasuportmaxima real,
	 emarruamento boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT fer_trecho_ferroviario_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX fer_trecho_ferroviario_l_geom ON edgv.fer_trecho_ferroviario_l USING gist (geom);

ALTER TABLE edgv.fer_trecho_ferroviario_l OWNER TO postgres;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_posicaorelativa_fk FOREIGN KEY (posicaorelativa)
	 REFERENCES dominios.posicao_relativa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN posicaorelativa SET DEFAULT 9999;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_tipotrechoferrov_fk FOREIGN KEY (tipotrechoferrov)
	 REFERENCES dominios.tipo_trecho_ferrov (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN tipotrechoferrov SET DEFAULT 9999;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_bitola_fk FOREIGN KEY (bitola)
	 REFERENCES dominios.bitola (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN bitola SET DEFAULT 9999;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_eletrificada_fk FOREIGN KEY (eletrificada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN eletrificada SET DEFAULT 9999;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_nrlinhas_fk FOREIGN KEY (nrlinhas)
	 REFERENCES dominios.nr_linhas (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN nrlinhas SET DEFAULT 9999;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.fer_trecho_ferroviario_l
	 ADD CONSTRAINT fer_trecho_ferroviario_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_trecho_ferroviario_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.fer_cremalheira_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT fer_cremalheira_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX fer_cremalheira_l_geom ON edgv.fer_cremalheira_l USING gist (geom);

ALTER TABLE edgv.fer_cremalheira_l OWNER TO postgres;

ALTER TABLE edgv.fer_cremalheira_l
	 ADD CONSTRAINT fer_cremalheira_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_cremalheira_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.fer_cremalheira_l
	 ADD CONSTRAINT fer_cremalheira_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_cremalheira_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.fer_cremalheira_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT fer_cremalheira_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX fer_cremalheira_p_geom ON edgv.fer_cremalheira_p USING gist (geom);

ALTER TABLE edgv.fer_cremalheira_p OWNER TO postgres;

ALTER TABLE edgv.fer_cremalheira_p
	 ADD CONSTRAINT fer_cremalheira_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_cremalheira_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.fer_cremalheira_p
	 ADD CONSTRAINT fer_cremalheira_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.fer_cremalheira_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hdv_eclusa_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 desnivel real,
	 largura real,
	 extensao real,
	 calado real,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hdv_eclusa_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_eclusa_l_geom ON edgv.hdv_eclusa_l USING gist (geom);

ALTER TABLE edgv.hdv_eclusa_l OWNER TO postgres;

ALTER TABLE edgv.hdv_eclusa_l
	 ADD CONSTRAINT hdv_eclusa_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hdv_eclusa_l
	 ADD CONSTRAINT hdv_eclusa_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hdv_eclusa_l
	 ADD CONSTRAINT hdv_eclusa_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hdv_eclusa_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 desnivel real,
	 largura real,
	 extensao real,
	 calado real,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hdv_eclusa_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_eclusa_p_geom ON edgv.hdv_eclusa_p USING gist (geom);

ALTER TABLE edgv.hdv_eclusa_p OWNER TO postgres;

ALTER TABLE edgv.hdv_eclusa_p
	 ADD CONSTRAINT hdv_eclusa_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hdv_eclusa_p
	 ADD CONSTRAINT hdv_eclusa_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hdv_eclusa_p
	 ADD CONSTRAINT hdv_eclusa_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hdv_eclusa_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 desnivel real,
	 largura real,
	 extensao real,
	 calado real,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hdv_eclusa_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_eclusa_a_geom ON edgv.hdv_eclusa_a USING gist (geom);

ALTER TABLE edgv.hdv_eclusa_a OWNER TO postgres;

ALTER TABLE edgv.hdv_eclusa_a
	 ADD CONSTRAINT hdv_eclusa_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hdv_eclusa_a
	 ADD CONSTRAINT hdv_eclusa_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hdv_eclusa_a
	 ADD CONSTRAINT hdv_eclusa_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_eclusa_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hdv_obstaculo_navegacao_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoobst smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hdv_obstaculo_navegacao_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_obstaculo_navegacao_l_geom ON edgv.hdv_obstaculo_navegacao_l USING gist (geom);

ALTER TABLE edgv.hdv_obstaculo_navegacao_l OWNER TO postgres;

ALTER TABLE edgv.hdv_obstaculo_navegacao_l
	 ADD CONSTRAINT hdv_obstaculo_navegacao_l_tipoobst_fk FOREIGN KEY (tipoobst)
	 REFERENCES dominios.tipo_obst (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_obstaculo_navegacao_l ALTER COLUMN tipoobst SET DEFAULT 9999;

ALTER TABLE edgv.hdv_obstaculo_navegacao_l
	 ADD CONSTRAINT hdv_obstaculo_navegacao_l_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_obstaculo_navegacao_l ALTER COLUMN situacaoemagua SET DEFAULT 9999;

CREATE TABLE edgv.hdv_obstaculo_navegacao_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoobst smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hdv_obstaculo_navegacao_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_obstaculo_navegacao_p_geom ON edgv.hdv_obstaculo_navegacao_p USING gist (geom);

ALTER TABLE edgv.hdv_obstaculo_navegacao_p OWNER TO postgres;

ALTER TABLE edgv.hdv_obstaculo_navegacao_p
	 ADD CONSTRAINT hdv_obstaculo_navegacao_p_tipoobst_fk FOREIGN KEY (tipoobst)
	 REFERENCES dominios.tipo_obst (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_obstaculo_navegacao_p ALTER COLUMN tipoobst SET DEFAULT 9999;

ALTER TABLE edgv.hdv_obstaculo_navegacao_p
	 ADD CONSTRAINT hdv_obstaculo_navegacao_p_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_obstaculo_navegacao_p ALTER COLUMN situacaoemagua SET DEFAULT 9999;

CREATE TABLE edgv.hdv_obstaculo_navegacao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoobst smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hdv_obstaculo_navegacao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_obstaculo_navegacao_a_geom ON edgv.hdv_obstaculo_navegacao_a USING gist (geom);

ALTER TABLE edgv.hdv_obstaculo_navegacao_a OWNER TO postgres;

ALTER TABLE edgv.hdv_obstaculo_navegacao_a
	 ADD CONSTRAINT hdv_obstaculo_navegacao_a_tipoobst_fk FOREIGN KEY (tipoobst)
	 REFERENCES dominios.tipo_obst (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_obstaculo_navegacao_a ALTER COLUMN tipoobst SET DEFAULT 9999;

ALTER TABLE edgv.hdv_obstaculo_navegacao_a
	 ADD CONSTRAINT hdv_obstaculo_navegacao_a_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_obstaculo_navegacao_a ALTER COLUMN situacaoemagua SET DEFAULT 9999;

CREATE TABLE edgv.hdv_sinalizacao_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tiposinal smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hdv_sinalizacao_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_sinalizacao_p_geom ON edgv.hdv_sinalizacao_p USING gist (geom);

ALTER TABLE edgv.hdv_sinalizacao_p OWNER TO postgres;

ALTER TABLE edgv.hdv_sinalizacao_p
	 ADD CONSTRAINT hdv_sinalizacao_p_tiposinal_fk FOREIGN KEY (tiposinal)
	 REFERENCES dominios.tipo_sinal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_sinalizacao_p ALTER COLUMN tiposinal SET DEFAULT 9999;

ALTER TABLE edgv.hdv_sinalizacao_p
	 ADD CONSTRAINT hdv_sinalizacao_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_sinalizacao_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hdv_sinalizacao_p
	 ADD CONSTRAINT hdv_sinalizacao_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_sinalizacao_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hdv_atracadouro_terminal_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoatracad smallint NOT NULL,
	 administracao smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 aptidaooperacional smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hdv_atracadouro_terminal_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_atracadouro_terminal_l_geom ON edgv.hdv_atracadouro_terminal_l USING gist (geom);

ALTER TABLE edgv.hdv_atracadouro_terminal_l OWNER TO postgres;

ALTER TABLE edgv.hdv_atracadouro_terminal_l
	 ADD CONSTRAINT hdv_atracadouro_terminal_l_tipoatracad_fk FOREIGN KEY (tipoatracad)
	 REFERENCES dominios.tipo_atracad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_l ALTER COLUMN tipoatracad SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_l
	 ADD CONSTRAINT hdv_atracadouro_terminal_l_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_l ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_l
	 ADD CONSTRAINT hdv_atracadouro_terminal_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_l
	 ADD CONSTRAINT hdv_atracadouro_terminal_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_l
	 ADD CONSTRAINT hdv_atracadouro_terminal_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_l
	 ADD CONSTRAINT hdv_atracadouro_terminal_l_aptidaooperacional_fk FOREIGN KEY (aptidaooperacional)
	 REFERENCES dominios.aptidao_operacional_atracadouro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_l ALTER COLUMN aptidaooperacional SET DEFAULT 9999;

CREATE TABLE edgv.hdv_atracadouro_terminal_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoatracad smallint NOT NULL,
	 administracao smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 aptidaooperacional smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hdv_atracadouro_terminal_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_atracadouro_terminal_p_geom ON edgv.hdv_atracadouro_terminal_p USING gist (geom);

ALTER TABLE edgv.hdv_atracadouro_terminal_p OWNER TO postgres;

ALTER TABLE edgv.hdv_atracadouro_terminal_p
	 ADD CONSTRAINT hdv_atracadouro_terminal_p_tipoatracad_fk FOREIGN KEY (tipoatracad)
	 REFERENCES dominios.tipo_atracad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_p ALTER COLUMN tipoatracad SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_p
	 ADD CONSTRAINT hdv_atracadouro_terminal_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_p ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_p
	 ADD CONSTRAINT hdv_atracadouro_terminal_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_p
	 ADD CONSTRAINT hdv_atracadouro_terminal_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_p
	 ADD CONSTRAINT hdv_atracadouro_terminal_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_p
	 ADD CONSTRAINT hdv_atracadouro_terminal_p_aptidaooperacional_fk FOREIGN KEY (aptidaooperacional)
	 REFERENCES dominios.aptidao_operacional_atracadouro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_p ALTER COLUMN aptidaooperacional SET DEFAULT 9999;

CREATE TABLE edgv.hdv_atracadouro_terminal_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoatracad smallint NOT NULL,
	 administracao smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 aptidaooperacional smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hdv_atracadouro_terminal_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_atracadouro_terminal_a_geom ON edgv.hdv_atracadouro_terminal_a USING gist (geom);

ALTER TABLE edgv.hdv_atracadouro_terminal_a OWNER TO postgres;

ALTER TABLE edgv.hdv_atracadouro_terminal_a
	 ADD CONSTRAINT hdv_atracadouro_terminal_a_tipoatracad_fk FOREIGN KEY (tipoatracad)
	 REFERENCES dominios.tipo_atracad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_a ALTER COLUMN tipoatracad SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_a
	 ADD CONSTRAINT hdv_atracadouro_terminal_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_a
	 ADD CONSTRAINT hdv_atracadouro_terminal_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_a
	 ADD CONSTRAINT hdv_atracadouro_terminal_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_a
	 ADD CONSTRAINT hdv_atracadouro_terminal_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.hdv_atracadouro_terminal_a
	 ADD CONSTRAINT hdv_atracadouro_terminal_a_aptidaooperacional_fk FOREIGN KEY (aptidaooperacional)
	 REFERENCES dominios.aptidao_operacional_atracadouro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_atracadouro_terminal_a ALTER COLUMN aptidaooperacional SET DEFAULT 9999;

CREATE TABLE edgv.hdv_fundeadouro_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipofundeadouro smallint NOT NULL,
	 administracao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hdv_fundeadouro_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_fundeadouro_p_geom ON edgv.hdv_fundeadouro_p USING gist (geom);

ALTER TABLE edgv.hdv_fundeadouro_p OWNER TO postgres;

ALTER TABLE edgv.hdv_fundeadouro_p
	 ADD CONSTRAINT hdv_fundeadouro_p_tipofundeadouro_fk FOREIGN KEY (tipofundeadouro)
	 REFERENCES dominios.tipo_fundeadouro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_fundeadouro_p ALTER COLUMN tipofundeadouro SET DEFAULT 9999;

ALTER TABLE edgv.hdv_fundeadouro_p
	 ADD CONSTRAINT hdv_fundeadouro_p_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_fundeadouro_p
	 ADD CONSTRAINT hdv_fundeadouro_p_administracao_check 
	 CHECK (administracao = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 7 :: SMALLINT, 15 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hdv_fundeadouro_p ALTER COLUMN administracao SET DEFAULT 9999;

CREATE TABLE edgv.hdv_fundeadouro_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipofundeadouro smallint NOT NULL,
	 administracao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hdv_fundeadouro_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_fundeadouro_a_geom ON edgv.hdv_fundeadouro_a USING gist (geom);

ALTER TABLE edgv.hdv_fundeadouro_a OWNER TO postgres;

ALTER TABLE edgv.hdv_fundeadouro_a
	 ADD CONSTRAINT hdv_fundeadouro_a_tipofundeadouro_fk FOREIGN KEY (tipofundeadouro)
	 REFERENCES dominios.tipo_fundeadouro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_fundeadouro_a ALTER COLUMN tipofundeadouro SET DEFAULT 9999;

ALTER TABLE edgv.hdv_fundeadouro_a
	 ADD CONSTRAINT hdv_fundeadouro_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_fundeadouro_a
	 ADD CONSTRAINT hdv_fundeadouro_a_administracao_check 
	 CHECK (administracao = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 7 :: SMALLINT, 15 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hdv_fundeadouro_a ALTER COLUMN administracao SET DEFAULT 9999;

CREATE TABLE edgv.hdv_trecho_hidroviario_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 regime smallint NOT NULL,
	 extensaotrecho real,
	 caladomaxseca real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hdv_trecho_hidroviario_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hdv_trecho_hidroviario_l_geom ON edgv.hdv_trecho_hidroviario_l USING gist (geom);

ALTER TABLE edgv.hdv_trecho_hidroviario_l OWNER TO postgres;

ALTER TABLE edgv.hdv_trecho_hidroviario_l
	 ADD CONSTRAINT hdv_trecho_hidroviario_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_trecho_hidroviario_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hdv_trecho_hidroviario_l
	 ADD CONSTRAINT hdv_trecho_hidroviario_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_trecho_hidroviario_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.hdv_trecho_hidroviario_l
	 ADD CONSTRAINT hdv_trecho_hidroviario_l_regime_fk FOREIGN KEY (regime)
	 REFERENCES dominios.regime (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hdv_trecho_hidroviario_l ALTER COLUMN regime SET DEFAULT 9999;

CREATE TABLE edgv.hid_sumidouro_vertedouro_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tiposumvert smallint NOT NULL,
	 causa smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_sumidouro_vertedouro_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_sumidouro_vertedouro_p_geom ON edgv.hid_sumidouro_vertedouro_p USING gist (geom);

ALTER TABLE edgv.hid_sumidouro_vertedouro_p OWNER TO postgres;

ALTER TABLE edgv.hid_sumidouro_vertedouro_p
	 ADD CONSTRAINT hid_sumidouro_vertedouro_p_tiposumvert_fk FOREIGN KEY (tiposumvert)
	 REFERENCES dominios.tipo_sum_vert (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_sumidouro_vertedouro_p ALTER COLUMN tiposumvert SET DEFAULT 9999;

ALTER TABLE edgv.hid_sumidouro_vertedouro_p
	 ADD CONSTRAINT hid_sumidouro_vertedouro_p_causa_fk FOREIGN KEY (causa)
	 REFERENCES dominios.causa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_sumidouro_vertedouro_p ALTER COLUMN causa SET DEFAULT 9999;

CREATE TABLE edgv.hid_ilha_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 tipoilha smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_ilha_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_ilha_p_geom ON edgv.hid_ilha_p USING gist (geom);

ALTER TABLE edgv.hid_ilha_p OWNER TO postgres;

ALTER TABLE edgv.hid_ilha_p
	 ADD CONSTRAINT hid_ilha_p_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_ilha_p
	 ADD CONSTRAINT hid_ilha_p_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[21 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_ilha_p ALTER COLUMN tipoelemnat SET DEFAULT 9999;

ALTER TABLE edgv.hid_ilha_p
	 ADD CONSTRAINT hid_ilha_p_tipoilha_fk FOREIGN KEY (tipoilha)
	 REFERENCES dominios.tipo_ilha (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_ilha_p ALTER COLUMN tipoilha SET DEFAULT 9999;

CREATE TABLE edgv.hid_ilha_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 tipoilha smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_ilha_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_ilha_a_geom ON edgv.hid_ilha_a USING gist (geom);

ALTER TABLE edgv.hid_ilha_a OWNER TO postgres;

ALTER TABLE edgv.hid_ilha_a
	 ADD CONSTRAINT hid_ilha_a_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_ilha_a
	 ADD CONSTRAINT hid_ilha_a_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[21 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_ilha_a ALTER COLUMN tipoelemnat SET DEFAULT 9999;

ALTER TABLE edgv.hid_ilha_a
	 ADD CONSTRAINT hid_ilha_a_tipoilha_fk FOREIGN KEY (tipoilha)
	 REFERENCES dominios.tipo_ilha (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_ilha_a ALTER COLUMN tipoilha SET DEFAULT 9999;

CREATE TABLE edgv.hid_vala_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 usoprincipal smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_vala_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_vala_l_geom ON edgv.hid_vala_l USING gist (geom);

ALTER TABLE edgv.hid_vala_l OWNER TO postgres;

ALTER TABLE edgv.hid_vala_l
	 ADD CONSTRAINT hid_vala_l_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_l
	 ADD CONSTRAINT hid_vala_l_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[31 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_vala_l ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_l
	 ADD CONSTRAINT hid_vala_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_l
	 ADD CONSTRAINT hid_vala_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_l
	 ADD CONSTRAINT hid_vala_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_l
	 ADD CONSTRAINT hid_vala_l_usoprincipal_fk FOREIGN KEY (usoprincipal)
	 REFERENCES dominios.uso_principal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_l ALTER COLUMN usoprincipal SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_l
	 ADD CONSTRAINT hid_vala_l_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_galeria_bueiro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_l
	 ADD CONSTRAINT hid_vala_l_finalidade_check 
	 CHECK (finalidade = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_vala_l ALTER COLUMN finalidade SET DEFAULT 9999;

CREATE TABLE edgv.hid_vala_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 usoprincipal smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_vala_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_vala_a_geom ON edgv.hid_vala_a USING gist (geom);

ALTER TABLE edgv.hid_vala_a OWNER TO postgres;

ALTER TABLE edgv.hid_vala_a
	 ADD CONSTRAINT hid_vala_a_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_a
	 ADD CONSTRAINT hid_vala_a_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[31 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_vala_a ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_a
	 ADD CONSTRAINT hid_vala_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_a
	 ADD CONSTRAINT hid_vala_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_a
	 ADD CONSTRAINT hid_vala_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_a
	 ADD CONSTRAINT hid_vala_a_usoprincipal_fk FOREIGN KEY (usoprincipal)
	 REFERENCES dominios.uso_principal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_a ALTER COLUMN usoprincipal SET DEFAULT 9999;

ALTER TABLE edgv.hid_vala_a
	 ADD CONSTRAINT hid_vala_a_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_galeria_bueiro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_vala_a
	 ADD CONSTRAINT hid_vala_a_finalidade_check 
	 CHECK (finalidade = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_vala_a ALTER COLUMN finalidade SET DEFAULT 9999;

CREATE TABLE edgv.hid_dique_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_dique_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_dique_l_geom ON edgv.hid_dique_l USING gist (geom);

ALTER TABLE edgv.hid_dique_l OWNER TO postgres;

ALTER TABLE edgv.hid_dique_l
	 ADD CONSTRAINT hid_dique_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_dique_l ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.hid_dique_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_dique_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_dique_p_geom ON edgv.hid_dique_p USING gist (geom);

ALTER TABLE edgv.hid_dique_p OWNER TO postgres;

ALTER TABLE edgv.hid_dique_p
	 ADD CONSTRAINT hid_dique_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_dique_p ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.hid_dique_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_dique_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_dique_a_geom ON edgv.hid_dique_a USING gist (geom);

ALTER TABLE edgv.hid_dique_a OWNER TO postgres;

ALTER TABLE edgv.hid_dique_a
	 ADD CONSTRAINT hid_dique_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_dique_a ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.hid_canal_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 usoprincipal smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_canal_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_canal_l_geom ON edgv.hid_canal_l USING gist (geom);

ALTER TABLE edgv.hid_canal_l OWNER TO postgres;

ALTER TABLE edgv.hid_canal_l
	 ADD CONSTRAINT hid_canal_l_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_l
	 ADD CONSTRAINT hid_canal_l_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[30 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_canal_l ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_l
	 ADD CONSTRAINT hid_canal_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_l
	 ADD CONSTRAINT hid_canal_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_l
	 ADD CONSTRAINT hid_canal_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_l
	 ADD CONSTRAINT hid_canal_l_usoprincipal_fk FOREIGN KEY (usoprincipal)
	 REFERENCES dominios.uso_principal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_l ALTER COLUMN usoprincipal SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_l
	 ADD CONSTRAINT hid_canal_l_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_galeria_bueiro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_l
	 ADD CONSTRAINT hid_canal_l_finalidade_check 
	 CHECK (finalidade = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_canal_l ALTER COLUMN finalidade SET DEFAULT 9999;

CREATE TABLE edgv.hid_canal_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 usoprincipal smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_canal_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_canal_a_geom ON edgv.hid_canal_a USING gist (geom);

ALTER TABLE edgv.hid_canal_a OWNER TO postgres;

ALTER TABLE edgv.hid_canal_a
	 ADD CONSTRAINT hid_canal_a_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_a
	 ADD CONSTRAINT hid_canal_a_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[30 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_canal_a ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_a
	 ADD CONSTRAINT hid_canal_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_a
	 ADD CONSTRAINT hid_canal_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_a
	 ADD CONSTRAINT hid_canal_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_a
	 ADD CONSTRAINT hid_canal_a_usoprincipal_fk FOREIGN KEY (usoprincipal)
	 REFERENCES dominios.uso_principal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_a ALTER COLUMN usoprincipal SET DEFAULT 9999;

ALTER TABLE edgv.hid_canal_a
	 ADD CONSTRAINT hid_canal_a_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_galeria_bueiro (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_canal_a
	 ADD CONSTRAINT hid_canal_a_finalidade_check 
	 CHECK (finalidade = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_canal_a ALTER COLUMN finalidade SET DEFAULT 9999;

CREATE TABLE edgv.hid_massa_dagua_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipomassadagua smallint NOT NULL,
	 regime smallint NOT NULL,
	 salgada smallint NOT NULL,
	 dominialidade smallint NOT NULL,
	 artificial smallint NOT NULL,
	 possuitrechodrenagem boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_massa_dagua_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_massa_dagua_a_geom ON edgv.hid_massa_dagua_a USING gist (geom);

ALTER TABLE edgv.hid_massa_dagua_a OWNER TO postgres;

ALTER TABLE edgv.hid_massa_dagua_a
	 ADD CONSTRAINT hid_massa_dagua_a_tipomassadagua_fk FOREIGN KEY (tipomassadagua)
	 REFERENCES dominios.tipo_massa_dagua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_massa_dagua_a ALTER COLUMN tipomassadagua SET DEFAULT 9999;

ALTER TABLE edgv.hid_massa_dagua_a
	 ADD CONSTRAINT hid_massa_dagua_a_regime_fk FOREIGN KEY (regime)
	 REFERENCES dominios.regime (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_massa_dagua_a ALTER COLUMN regime SET DEFAULT 9999;

ALTER TABLE edgv.hid_massa_dagua_a
	 ADD CONSTRAINT hid_massa_dagua_a_salgada_fk FOREIGN KEY (salgada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_massa_dagua_a ALTER COLUMN salgada SET DEFAULT 9999;

ALTER TABLE edgv.hid_massa_dagua_a
	 ADD CONSTRAINT hid_massa_dagua_a_dominialidade_fk FOREIGN KEY (dominialidade)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_massa_dagua_a ALTER COLUMN dominialidade SET DEFAULT 9999;

ALTER TABLE edgv.hid_massa_dagua_a
	 ADD CONSTRAINT hid_massa_dagua_a_artificial_fk FOREIGN KEY (artificial)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_massa_dagua_a ALTER COLUMN artificial SET DEFAULT 9999;

CREATE TABLE edgv.hid_trecho_drenagem_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipotrechodrenagem smallint NOT NULL,
	 navegavel smallint NOT NULL,
	 larguramedia real,
	 regime smallint NOT NULL,
	 encoberto boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_trecho_drenagem_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_trecho_drenagem_l_geom ON edgv.hid_trecho_drenagem_l USING gist (geom);

ALTER TABLE edgv.hid_trecho_drenagem_l OWNER TO postgres;

ALTER TABLE edgv.hid_trecho_drenagem_l
	 ADD CONSTRAINT hid_trecho_drenagem_l_tipotrechodrenagem_fk FOREIGN KEY (tipotrechodrenagem)
	 REFERENCES dominios.tipo_trecho_drenagem (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_trecho_drenagem_l ALTER COLUMN tipotrechodrenagem SET DEFAULT 9999;

ALTER TABLE edgv.hid_trecho_drenagem_l
	 ADD CONSTRAINT hid_trecho_drenagem_l_navegavel_fk FOREIGN KEY (navegavel)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_trecho_drenagem_l ALTER COLUMN navegavel SET DEFAULT 9999;

ALTER TABLE edgv.hid_trecho_drenagem_l
	 ADD CONSTRAINT hid_trecho_drenagem_l_regime_fk FOREIGN KEY (regime)
	 REFERENCES dominios.regime (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_trecho_drenagem_l ALTER COLUMN regime SET DEFAULT 9999;

CREATE TABLE edgv.hid_comporta_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_comporta_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_comporta_l_geom ON edgv.hid_comporta_l USING gist (geom);

ALTER TABLE edgv.hid_comporta_l OWNER TO postgres;

ALTER TABLE edgv.hid_comporta_l
	 ADD CONSTRAINT hid_comporta_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_comporta_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_comporta_l
	 ADD CONSTRAINT hid_comporta_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_comporta_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hid_comporta_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_comporta_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_comporta_p_geom ON edgv.hid_comporta_p USING gist (geom);

ALTER TABLE edgv.hid_comporta_p OWNER TO postgres;

ALTER TABLE edgv.hid_comporta_p
	 ADD CONSTRAINT hid_comporta_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_comporta_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_comporta_p
	 ADD CONSTRAINT hid_comporta_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_comporta_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hid_corredeira_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_corredeira_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_corredeira_l_geom ON edgv.hid_corredeira_l USING gist (geom);

ALTER TABLE edgv.hid_corredeira_l OWNER TO postgres;

CREATE TABLE edgv.hid_corredeira_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_corredeira_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_corredeira_p_geom ON edgv.hid_corredeira_p USING gist (geom);

ALTER TABLE edgv.hid_corredeira_p OWNER TO postgres;

CREATE TABLE edgv.hid_corredeira_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_corredeira_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_corredeira_a_geom ON edgv.hid_corredeira_a USING gist (geom);

ALTER TABLE edgv.hid_corredeira_a OWNER TO postgres;

CREATE TABLE edgv.hid_queda_dagua_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoqueda smallint NOT NULL,
	 altura real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_queda_dagua_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_queda_dagua_p_geom ON edgv.hid_queda_dagua_p USING gist (geom);

ALTER TABLE edgv.hid_queda_dagua_p OWNER TO postgres;

ALTER TABLE edgv.hid_queda_dagua_p
	 ADD CONSTRAINT hid_queda_dagua_p_tipoqueda_fk FOREIGN KEY (tipoqueda)
	 REFERENCES dominios.tipo_queda (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_queda_dagua_p ALTER COLUMN tipoqueda SET DEFAULT 9999;

CREATE TABLE edgv.hid_queda_dagua_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoqueda smallint NOT NULL,
	 altura real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_queda_dagua_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_queda_dagua_l_geom ON edgv.hid_queda_dagua_l USING gist (geom);

ALTER TABLE edgv.hid_queda_dagua_l OWNER TO postgres;

ALTER TABLE edgv.hid_queda_dagua_l
	 ADD CONSTRAINT hid_queda_dagua_l_tipoqueda_fk FOREIGN KEY (tipoqueda)
	 REFERENCES dominios.tipo_queda (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_queda_dagua_l ALTER COLUMN tipoqueda SET DEFAULT 9999;

CREATE TABLE edgv.hid_recife_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tiporecife smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 situacaocosta smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_recife_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_recife_p_geom ON edgv.hid_recife_p USING gist (geom);

ALTER TABLE edgv.hid_recife_p OWNER TO postgres;

ALTER TABLE edgv.hid_recife_p
	 ADD CONSTRAINT hid_recife_p_tiporecife_fk FOREIGN KEY (tiporecife)
	 REFERENCES dominios.tipo_recife (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_recife_p ALTER COLUMN tiporecife SET DEFAULT 9999;

ALTER TABLE edgv.hid_recife_p
	 ADD CONSTRAINT hid_recife_p_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_recife_p ALTER COLUMN situacaoemagua SET DEFAULT 9999;

ALTER TABLE edgv.hid_recife_p
	 ADD CONSTRAINT hid_recife_p_situacaocosta_fk FOREIGN KEY (situacaocosta)
	 REFERENCES dominios.situacao_costa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_recife_p ALTER COLUMN situacaocosta SET DEFAULT 9999;

CREATE TABLE edgv.hid_recife_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tiporecife smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 situacaocosta smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_recife_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_recife_a_geom ON edgv.hid_recife_a USING gist (geom);

ALTER TABLE edgv.hid_recife_a OWNER TO postgres;

ALTER TABLE edgv.hid_recife_a
	 ADD CONSTRAINT hid_recife_a_tiporecife_fk FOREIGN KEY (tiporecife)
	 REFERENCES dominios.tipo_recife (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_recife_a ALTER COLUMN tiporecife SET DEFAULT 9999;

ALTER TABLE edgv.hid_recife_a
	 ADD CONSTRAINT hid_recife_a_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_recife_a ALTER COLUMN situacaoemagua SET DEFAULT 9999;

ALTER TABLE edgv.hid_recife_a
	 ADD CONSTRAINT hid_recife_a_situacaocosta_fk FOREIGN KEY (situacaocosta)
	 REFERENCES dominios.situacao_costa (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_recife_a ALTER COLUMN situacaocosta SET DEFAULT 9999;

CREATE TABLE edgv.hid_terreno_sujeito_inundacao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 periodicidadeinunda varchar(20),
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_terreno_sujeito_inundacao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_terreno_sujeito_inundacao_a_geom ON edgv.hid_terreno_sujeito_inundacao_a USING gist (geom);

ALTER TABLE edgv.hid_terreno_sujeito_inundacao_a OWNER TO postgres;

CREATE TABLE edgv.hid_rocha_em_agua_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 formarocha smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 alturalamina real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_rocha_em_agua_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_rocha_em_agua_p_geom ON edgv.hid_rocha_em_agua_p USING gist (geom);

ALTER TABLE edgv.hid_rocha_em_agua_p OWNER TO postgres;

ALTER TABLE edgv.hid_rocha_em_agua_p
	 ADD CONSTRAINT hid_rocha_em_agua_p_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_rocha_em_agua_p
	 ADD CONSTRAINT hid_rocha_em_agua_p_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[23 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_rocha_em_agua_p ALTER COLUMN tipoelemnat SET DEFAULT 9999;

ALTER TABLE edgv.hid_rocha_em_agua_p
	 ADD CONSTRAINT hid_rocha_em_agua_p_formarocha_fk FOREIGN KEY (formarocha)
	 REFERENCES dominios.forma_rocha (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_rocha_em_agua_p ALTER COLUMN formarocha SET DEFAULT 9999;

ALTER TABLE edgv.hid_rocha_em_agua_p
	 ADD CONSTRAINT hid_rocha_em_agua_p_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_rocha_em_agua_p ALTER COLUMN situacaoemagua SET DEFAULT 9999;

CREATE TABLE edgv.hid_rocha_em_agua_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 formarocha smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 alturalamina real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_rocha_em_agua_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_rocha_em_agua_a_geom ON edgv.hid_rocha_em_agua_a USING gist (geom);

ALTER TABLE edgv.hid_rocha_em_agua_a OWNER TO postgres;

ALTER TABLE edgv.hid_rocha_em_agua_a
	 ADD CONSTRAINT hid_rocha_em_agua_a_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_rocha_em_agua_a
	 ADD CONSTRAINT hid_rocha_em_agua_a_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[23 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.hid_rocha_em_agua_a ALTER COLUMN tipoelemnat SET DEFAULT 9999;

ALTER TABLE edgv.hid_rocha_em_agua_a
	 ADD CONSTRAINT hid_rocha_em_agua_a_formarocha_fk FOREIGN KEY (formarocha)
	 REFERENCES dominios.forma_rocha (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_rocha_em_agua_a ALTER COLUMN formarocha SET DEFAULT 9999;

ALTER TABLE edgv.hid_rocha_em_agua_a
	 ADD CONSTRAINT hid_rocha_em_agua_a_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_rocha_em_agua_a ALTER COLUMN situacaoemagua SET DEFAULT 9999;

CREATE TABLE edgv.hid_banco_areia_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipobanco smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 materialpredominante smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_banco_areia_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_banco_areia_a_geom ON edgv.hid_banco_areia_a USING gist (geom);

ALTER TABLE edgv.hid_banco_areia_a OWNER TO postgres;

ALTER TABLE edgv.hid_banco_areia_a
	 ADD CONSTRAINT hid_banco_areia_a_tipobanco_fk FOREIGN KEY (tipobanco)
	 REFERENCES dominios.tipo_banco (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_banco_areia_a ALTER COLUMN tipobanco SET DEFAULT 9999;

ALTER TABLE edgv.hid_banco_areia_a
	 ADD CONSTRAINT hid_banco_areia_a_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_banco_areia_a ALTER COLUMN situacaoemagua SET DEFAULT 9999;

ALTER TABLE edgv.hid_banco_areia_a
	 ADD CONSTRAINT hid_banco_areia_a_materialpredominante_fk FOREIGN KEY (materialpredominante)
	 REFERENCES dominios.material_predominante (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_banco_areia_a ALTER COLUMN materialpredominante SET DEFAULT 9999;

CREATE TABLE edgv.hid_quebramar_molhe_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoquebramolhe smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_quebramar_molhe_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_quebramar_molhe_l_geom ON edgv.hid_quebramar_molhe_l USING gist (geom);

ALTER TABLE edgv.hid_quebramar_molhe_l OWNER TO postgres;

ALTER TABLE edgv.hid_quebramar_molhe_l
	 ADD CONSTRAINT hid_quebramar_molhe_l_tipoquebramolhe_fk FOREIGN KEY (tipoquebramolhe)
	 REFERENCES dominios.tipo_quebra_molhe (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_l ALTER COLUMN tipoquebramolhe SET DEFAULT 9999;

ALTER TABLE edgv.hid_quebramar_molhe_l
	 ADD CONSTRAINT hid_quebramar_molhe_l_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_l ALTER COLUMN situacaoemagua SET DEFAULT 9999;

ALTER TABLE edgv.hid_quebramar_molhe_l
	 ADD CONSTRAINT hid_quebramar_molhe_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_quebramar_molhe_l
	 ADD CONSTRAINT hid_quebramar_molhe_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_quebramar_molhe_l
	 ADD CONSTRAINT hid_quebramar_molhe_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hid_quebramar_molhe_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoquebramolhe smallint NOT NULL,
	 situacaoemagua smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_quebramar_molhe_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_quebramar_molhe_a_geom ON edgv.hid_quebramar_molhe_a USING gist (geom);

ALTER TABLE edgv.hid_quebramar_molhe_a OWNER TO postgres;

ALTER TABLE edgv.hid_quebramar_molhe_a
	 ADD CONSTRAINT hid_quebramar_molhe_a_tipoquebramolhe_fk FOREIGN KEY (tipoquebramolhe)
	 REFERENCES dominios.tipo_quebra_molhe (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_a ALTER COLUMN tipoquebramolhe SET DEFAULT 9999;

ALTER TABLE edgv.hid_quebramar_molhe_a
	 ADD CONSTRAINT hid_quebramar_molhe_a_situacaoemagua_fk FOREIGN KEY (situacaoemagua)
	 REFERENCES dominios.situacao_em_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_a ALTER COLUMN situacaoemagua SET DEFAULT 9999;

ALTER TABLE edgv.hid_quebramar_molhe_a
	 ADD CONSTRAINT hid_quebramar_molhe_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_quebramar_molhe_a
	 ADD CONSTRAINT hid_quebramar_molhe_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_quebramar_molhe_a
	 ADD CONSTRAINT hid_quebramar_molhe_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_quebramar_molhe_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hid_foz_maritima_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_foz_maritima_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_foz_maritima_a_geom ON edgv.hid_foz_maritima_a USING gist (geom);

ALTER TABLE edgv.hid_foz_maritima_a OWNER TO postgres;

CREATE TABLE edgv.hid_foz_maritima_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_foz_maritima_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_foz_maritima_l_geom ON edgv.hid_foz_maritima_l USING gist (geom);

ALTER TABLE edgv.hid_foz_maritima_l OWNER TO postgres;

CREATE TABLE edgv.hid_foz_maritima_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_foz_maritima_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_foz_maritima_p_geom ON edgv.hid_foz_maritima_p USING gist (geom);

ALTER TABLE edgv.hid_foz_maritima_p OWNER TO postgres;

CREATE TABLE edgv.hid_fonte_dagua_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipofontedagua smallint NOT NULL,
	 qualidagua smallint NOT NULL,
	 regime smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_fonte_dagua_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_fonte_dagua_p_geom ON edgv.hid_fonte_dagua_p USING gist (geom);

ALTER TABLE edgv.hid_fonte_dagua_p OWNER TO postgres;

ALTER TABLE edgv.hid_fonte_dagua_p
	 ADD CONSTRAINT hid_fonte_dagua_p_tipofontedagua_fk FOREIGN KEY (tipofontedagua)
	 REFERENCES dominios.tipo_fonte_dagua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_fonte_dagua_p ALTER COLUMN tipofontedagua SET DEFAULT 9999;

ALTER TABLE edgv.hid_fonte_dagua_p
	 ADD CONSTRAINT hid_fonte_dagua_p_qualidagua_fk FOREIGN KEY (qualidagua)
	 REFERENCES dominios.qualid_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_fonte_dagua_p ALTER COLUMN qualidagua SET DEFAULT 9999;

ALTER TABLE edgv.hid_fonte_dagua_p
	 ADD CONSTRAINT hid_fonte_dagua_p_regime_fk FOREIGN KEY (regime)
	 REFERENCES dominios.regime (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_fonte_dagua_p ALTER COLUMN regime SET DEFAULT 9999;

CREATE TABLE edgv.hid_area_umida_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoareaumida smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_area_umida_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_area_umida_a_geom ON edgv.hid_area_umida_a USING gist (geom);

ALTER TABLE edgv.hid_area_umida_a OWNER TO postgres;

ALTER TABLE edgv.hid_area_umida_a
	 ADD CONSTRAINT hid_area_umida_a_tipoareaumida_fk FOREIGN KEY (tipoareaumida)
	 REFERENCES dominios.tipo_area_umida (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_area_umida_a ALTER COLUMN tipoareaumida SET DEFAULT 9999;

CREATE TABLE edgv.hid_barragem_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 matconstr smallint NOT NULL,
	 usoprincipal smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT hid_barragem_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_barragem_l_geom ON edgv.hid_barragem_l USING gist (geom);

ALTER TABLE edgv.hid_barragem_l OWNER TO postgres;

ALTER TABLE edgv.hid_barragem_l
	 ADD CONSTRAINT hid_barragem_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_l
	 ADD CONSTRAINT hid_barragem_l_usoprincipal_fk FOREIGN KEY (usoprincipal)
	 REFERENCES dominios.uso_principal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_l ALTER COLUMN usoprincipal SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_l
	 ADD CONSTRAINT hid_barragem_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_l
	 ADD CONSTRAINT hid_barragem_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hid_barragem_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 matconstr smallint NOT NULL,
	 usoprincipal smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT hid_barragem_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_barragem_p_geom ON edgv.hid_barragem_p USING gist (geom);

ALTER TABLE edgv.hid_barragem_p OWNER TO postgres;

ALTER TABLE edgv.hid_barragem_p
	 ADD CONSTRAINT hid_barragem_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_p
	 ADD CONSTRAINT hid_barragem_p_usoprincipal_fk FOREIGN KEY (usoprincipal)
	 REFERENCES dominios.uso_principal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_p ALTER COLUMN usoprincipal SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_p
	 ADD CONSTRAINT hid_barragem_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_p
	 ADD CONSTRAINT hid_barragem_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.hid_barragem_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 matconstr smallint NOT NULL,
	 usoprincipal smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT hid_barragem_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX hid_barragem_a_geom ON edgv.hid_barragem_a USING gist (geom);

ALTER TABLE edgv.hid_barragem_a OWNER TO postgres;

ALTER TABLE edgv.hid_barragem_a
	 ADD CONSTRAINT hid_barragem_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_a
	 ADD CONSTRAINT hid_barragem_a_usoprincipal_fk FOREIGN KEY (usoprincipal)
	 REFERENCES dominios.uso_principal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_a ALTER COLUMN usoprincipal SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_a
	 ADD CONSTRAINT hid_barragem_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.hid_barragem_a
	 ADD CONSTRAINT hid_barragem_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.hid_barragem_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.laz_sitio_arqueologico_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT laz_sitio_arqueologico_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_sitio_arqueologico_p_geom ON edgv.laz_sitio_arqueologico_p USING gist (geom);

ALTER TABLE edgv.laz_sitio_arqueologico_p OWNER TO postgres;

ALTER TABLE edgv.laz_sitio_arqueologico_p
	 ADD CONSTRAINT laz_sitio_arqueologico_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_sitio_arqueologico_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.laz_sitio_arqueologico_p
	 ADD CONSTRAINT laz_sitio_arqueologico_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_sitio_arqueologico_p
	 ADD CONSTRAINT laz_sitio_arqueologico_p_cultura_check 
	 CHECK (cultura = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.laz_sitio_arqueologico_p ALTER COLUMN cultura SET DEFAULT 9999;

CREATE TABLE edgv.laz_sitio_arqueologico_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT laz_sitio_arqueologico_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_sitio_arqueologico_a_geom ON edgv.laz_sitio_arqueologico_a USING gist (geom);

ALTER TABLE edgv.laz_sitio_arqueologico_a OWNER TO postgres;

ALTER TABLE edgv.laz_sitio_arqueologico_a
	 ADD CONSTRAINT laz_sitio_arqueologico_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_sitio_arqueologico_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.laz_sitio_arqueologico_a
	 ADD CONSTRAINT laz_sitio_arqueologico_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_sitio_arqueologico_a
	 ADD CONSTRAINT laz_sitio_arqueologico_a_cultura_check 
	 CHECK (cultura = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.laz_sitio_arqueologico_a ALTER COLUMN cultura SET DEFAULT 9999;

CREATE TABLE edgv.laz_pista_competicao_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipopistacomp smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT laz_pista_competicao_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_pista_competicao_l_geom ON edgv.laz_pista_competicao_l USING gist (geom);

ALTER TABLE edgv.laz_pista_competicao_l OWNER TO postgres;

ALTER TABLE edgv.laz_pista_competicao_l
	 ADD CONSTRAINT laz_pista_competicao_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.laz_pista_competicao_l
	 ADD CONSTRAINT laz_pista_competicao_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.laz_pista_competicao_l
	 ADD CONSTRAINT laz_pista_competicao_l_tipopistacomp_fk FOREIGN KEY (tipopistacomp)
	 REFERENCES dominios.tipo_pista_comp (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_l ALTER COLUMN tipopistacomp SET DEFAULT 9999;

CREATE TABLE edgv.laz_pista_competicao_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipopistacomp smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT laz_pista_competicao_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_pista_competicao_p_geom ON edgv.laz_pista_competicao_p USING gist (geom);

ALTER TABLE edgv.laz_pista_competicao_p OWNER TO postgres;

ALTER TABLE edgv.laz_pista_competicao_p
	 ADD CONSTRAINT laz_pista_competicao_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.laz_pista_competicao_p
	 ADD CONSTRAINT laz_pista_competicao_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.laz_pista_competicao_p
	 ADD CONSTRAINT laz_pista_competicao_p_tipopistacomp_fk FOREIGN KEY (tipopistacomp)
	 REFERENCES dominios.tipo_pista_comp (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_p ALTER COLUMN tipopistacomp SET DEFAULT 9999;

CREATE TABLE edgv.laz_pista_competicao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipopistacomp smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT laz_pista_competicao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_pista_competicao_a_geom ON edgv.laz_pista_competicao_a USING gist (geom);

ALTER TABLE edgv.laz_pista_competicao_a OWNER TO postgres;

ALTER TABLE edgv.laz_pista_competicao_a
	 ADD CONSTRAINT laz_pista_competicao_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.laz_pista_competicao_a
	 ADD CONSTRAINT laz_pista_competicao_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.laz_pista_competicao_a
	 ADD CONSTRAINT laz_pista_competicao_a_tipopistacomp_fk FOREIGN KEY (tipopistacomp)
	 REFERENCES dominios.tipo_pista_comp (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_pista_competicao_a ALTER COLUMN tipopistacomp SET DEFAULT 9999;

CREATE TABLE edgv.laz_arquibancada_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT laz_arquibancada_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_arquibancada_l_geom ON edgv.laz_arquibancada_l USING gist (geom);

ALTER TABLE edgv.laz_arquibancada_l OWNER TO postgres;

ALTER TABLE edgv.laz_arquibancada_l
	 ADD CONSTRAINT laz_arquibancada_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_arquibancada_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.laz_arquibancada_l
	 ADD CONSTRAINT laz_arquibancada_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_arquibancada_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.laz_arquibancada_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT laz_arquibancada_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_arquibancada_a_geom ON edgv.laz_arquibancada_a USING gist (geom);

ALTER TABLE edgv.laz_arquibancada_a OWNER TO postgres;

ALTER TABLE edgv.laz_arquibancada_a
	 ADD CONSTRAINT laz_arquibancada_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_arquibancada_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.laz_arquibancada_a
	 ADD CONSTRAINT laz_arquibancada_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_arquibancada_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.laz_campo_quadra_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipocampoquadra smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT laz_campo_quadra_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_campo_quadra_p_geom ON edgv.laz_campo_quadra_p USING gist (geom);

ALTER TABLE edgv.laz_campo_quadra_p OWNER TO postgres;

ALTER TABLE edgv.laz_campo_quadra_p
	 ADD CONSTRAINT laz_campo_quadra_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_campo_quadra_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.laz_campo_quadra_p
	 ADD CONSTRAINT laz_campo_quadra_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_campo_quadra_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.laz_campo_quadra_p
	 ADD CONSTRAINT laz_campo_quadra_p_tipocampoquadra_fk FOREIGN KEY (tipocampoquadra)
	 REFERENCES dominios.tipo_campo_quadra (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_campo_quadra_p ALTER COLUMN tipocampoquadra SET DEFAULT 9999;

CREATE TABLE edgv.laz_campo_quadra_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipocampoquadra smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT laz_campo_quadra_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_campo_quadra_a_geom ON edgv.laz_campo_quadra_a USING gist (geom);

ALTER TABLE edgv.laz_campo_quadra_a OWNER TO postgres;

ALTER TABLE edgv.laz_campo_quadra_a
	 ADD CONSTRAINT laz_campo_quadra_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_campo_quadra_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.laz_campo_quadra_a
	 ADD CONSTRAINT laz_campo_quadra_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_campo_quadra_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.laz_campo_quadra_a
	 ADD CONSTRAINT laz_campo_quadra_a_tipocampoquadra_fk FOREIGN KEY (tipocampoquadra)
	 REFERENCES dominios.tipo_campo_quadra (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_campo_quadra_a ALTER COLUMN tipocampoquadra SET DEFAULT 9999;

CREATE TABLE edgv.laz_piscina_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT laz_piscina_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_piscina_a_geom ON edgv.laz_piscina_a USING gist (geom);

ALTER TABLE edgv.laz_piscina_a OWNER TO postgres;

ALTER TABLE edgv.laz_piscina_a
	 ADD CONSTRAINT laz_piscina_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_piscina_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.laz_piscina_a
	 ADD CONSTRAINT laz_piscina_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_piscina_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.laz_ruina_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT laz_ruina_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_ruina_p_geom ON edgv.laz_ruina_p USING gist (geom);

ALTER TABLE edgv.laz_ruina_p OWNER TO postgres;

ALTER TABLE edgv.laz_ruina_p
	 ADD CONSTRAINT laz_ruina_p_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_ruina_p ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.laz_ruina_p
	 ADD CONSTRAINT laz_ruina_p_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_ruina_p
	 ADD CONSTRAINT laz_ruina_p_cultura_check 
	 CHECK (cultura = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.laz_ruina_p ALTER COLUMN cultura SET DEFAULT 9999;

CREATE TABLE edgv.laz_ruina_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 turistica smallint NOT NULL,
	 cultura smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT laz_ruina_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX laz_ruina_a_geom ON edgv.laz_ruina_a USING gist (geom);

ALTER TABLE edgv.laz_ruina_a OWNER TO postgres;

ALTER TABLE edgv.laz_ruina_a
	 ADD CONSTRAINT laz_ruina_a_turistica_fk FOREIGN KEY (turistica)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_ruina_a ALTER COLUMN turistica SET DEFAULT 9999;

ALTER TABLE edgv.laz_ruina_a
	 ADD CONSTRAINT laz_ruina_a_cultura_fk FOREIGN KEY (cultura)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.laz_ruina_a
	 ADD CONSTRAINT laz_ruina_a_cultura_check 
	 CHECK (cultura = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.laz_ruina_a ALTER COLUMN cultura SET DEFAULT 9999;

CREATE TABLE edgv.lml_pais_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 sigla varchar(3),
	 codiso3166 varchar(3),
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_pais_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_pais_a_geom ON edgv.lml_pais_a USING gist (geom);

ALTER TABLE edgv.lml_pais_a OWNER TO postgres;

CREATE TABLE edgv.lml_posic_geo_localidade_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 identificador varchar(255),
	 latitude varchar(16),
	 longitude varchar(16),
	 nomelocal varchar(255),
	 anodereferencia integer,
	 tipolocalidade smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT lml_posic_geo_localidade_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_posic_geo_localidade_p_geom ON edgv.lml_posic_geo_localidade_p USING gist (geom);

ALTER TABLE edgv.lml_posic_geo_localidade_p OWNER TO postgres;

ALTER TABLE edgv.lml_posic_geo_localidade_p
	 ADD CONSTRAINT lml_posic_geo_localidade_p_tipolocalidade_fk FOREIGN KEY (tipolocalidade)
	 REFERENCES dominios.tipo_localidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_posic_geo_localidade_p ALTER COLUMN tipolocalidade SET DEFAULT 9999;

CREATE TABLE edgv.lml_distrito_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 geocodigo varchar(15),
	 anodereferencia integer,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_distrito_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_distrito_a_geom ON edgv.lml_distrito_a USING gist (geom);

ALTER TABLE edgv.lml_distrito_a OWNER TO postgres;

CREATE TABLE edgv.lml_area_densamente_edificada_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_area_densamente_edificada_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_area_densamente_edificada_a_geom ON edgv.lml_area_densamente_edificada_a USING gist (geom);

ALTER TABLE edgv.lml_area_densamente_edificada_a OWNER TO postgres;

CREATE TABLE edgv.lml_unidade_federacao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 geocodigo varchar(15),
	 sigla smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_unidade_federacao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_unidade_federacao_a_geom ON edgv.lml_unidade_federacao_a USING gist (geom);

ALTER TABLE edgv.lml_unidade_federacao_a OWNER TO postgres;

ALTER TABLE edgv.lml_unidade_federacao_a
	 ADD CONSTRAINT lml_unidade_federacao_a_sigla_fk FOREIGN KEY (sigla)
	 REFERENCES dominios.sigla_uf (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_federacao_a ALTER COLUMN sigla SET DEFAULT 9999;

CREATE TABLE edgv.lml_terra_indigena_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 codidentificadorunico varchar(50),
	 arealegal real,
	 classificacao varchar(255),
	 jurisdicao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 situacaojuridica smallint NOT NULL,
	 datasituacaojuridica varchar(10),
	 grupoetnico varchar(255),
	 perimetrooficial real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_terra_indigena_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_terra_indigena_a_geom ON edgv.lml_terra_indigena_a USING gist (geom);

ALTER TABLE edgv.lml_terra_indigena_a OWNER TO postgres;

ALTER TABLE edgv.lml_terra_indigena_a
	 ADD CONSTRAINT lml_terra_indigena_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_terra_indigena_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.lml_terra_indigena_a
	 ADD CONSTRAINT lml_terra_indigena_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_terra_indigena_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.lml_terra_indigena_a
	 ADD CONSTRAINT lml_terra_indigena_a_situacaojuridica_fk FOREIGN KEY (situacaojuridica)
	 REFERENCES dominios.situacao_juridica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_terra_indigena_a ALTER COLUMN situacaojuridica SET DEFAULT 9999;

CREATE TABLE edgv.lml_unidade_protecao_integral_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 codidentificadorunico varchar(50),
	 arealegal real,
	 anocriacao varchar(4),
	 historicomodificacoes varchar(255),
	 sigla varchar(255),
	 atolegal varchar(255),
	 areaoficial varchar(15),
	 administracao smallint NOT NULL,
	 classificacao varchar(255),
	 jurisdicao smallint NOT NULL,
	 tipounidprotegida smallint NOT NULL,
	 tipounidprotinteg smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_unidade_protecao_integral_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_unidade_protecao_integral_a_geom ON edgv.lml_unidade_protecao_integral_a USING gist (geom);

ALTER TABLE edgv.lml_unidade_protecao_integral_a OWNER TO postgres;

ALTER TABLE edgv.lml_unidade_protecao_integral_a
	 ADD CONSTRAINT lml_unidade_protecao_integral_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_protecao_integral_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.lml_unidade_protecao_integral_a
	 ADD CONSTRAINT lml_unidade_protecao_integral_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_protecao_integral_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.lml_unidade_protecao_integral_a
	 ADD CONSTRAINT lml_unidade_protecao_integral_a_tipounidprotegida_fk FOREIGN KEY (tipounidprotegida)
	 REFERENCES dominios.tipo_unid_protegida (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_protecao_integral_a
	 ADD CONSTRAINT lml_unidade_protecao_integral_a_tipounidprotegida_check 
	 CHECK (tipounidprotegida = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.lml_unidade_protecao_integral_a ALTER COLUMN tipounidprotegida SET DEFAULT 9999;

ALTER TABLE edgv.lml_unidade_protecao_integral_a
	 ADD CONSTRAINT lml_unidade_protecao_integral_a_tipounidprotinteg_fk FOREIGN KEY (tipounidprotinteg)
	 REFERENCES dominios.tipo_unid_prot_integ (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_protecao_integral_a ALTER COLUMN tipounidprotinteg SET DEFAULT 9999;

CREATE TABLE edgv.lml_unidade_uso_sustentavel_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 codidentificadorunico varchar(50),
	 arealegal real,
	 anocriacao varchar(4),
	 historicomodificacoes varchar(255),
	 sigla varchar(255),
	 atolegal varchar(255),
	 areaoficial varchar(15),
	 administracao smallint NOT NULL,
	 classificacao varchar(255),
	 jurisdicao smallint NOT NULL,
	 tipounidprotegida smallint NOT NULL,
	 tipounidusosust smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_unidade_uso_sustentavel_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_unidade_uso_sustentavel_a_geom ON edgv.lml_unidade_uso_sustentavel_a USING gist (geom);

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a OWNER TO postgres;

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a
	 ADD CONSTRAINT lml_unidade_uso_sustentavel_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a
	 ADD CONSTRAINT lml_unidade_uso_sustentavel_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a
	 ADD CONSTRAINT lml_unidade_uso_sustentavel_a_tipounidprotegida_fk FOREIGN KEY (tipounidprotegida)
	 REFERENCES dominios.tipo_unid_protegida (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a
	 ADD CONSTRAINT lml_unidade_uso_sustentavel_a_tipounidprotegida_check 
	 CHECK (tipounidprotegida = ANY(ARRAY[3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a ALTER COLUMN tipounidprotegida SET DEFAULT 9999;

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a
	 ADD CONSTRAINT lml_unidade_uso_sustentavel_a_tipounidusosust_fk FOREIGN KEY (tipounidusosust)
	 REFERENCES dominios.tipo_unid_uso_sust (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_uso_sustentavel_a ALTER COLUMN tipounidusosust SET DEFAULT 9999;

CREATE TABLE edgv.lml_municipio_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 geocodigo varchar(15),
	 anodereferencia integer,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_municipio_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_municipio_a_geom ON edgv.lml_municipio_a USING gist (geom);

ALTER TABLE edgv.lml_municipio_a OWNER TO postgres;

CREATE TABLE edgv.lml_terra_publica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 codidentificadorunico varchar(50),
	 arealegal real,
	 classificacao varchar(255),
	 jurisdicao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_terra_publica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_terra_publica_a_geom ON edgv.lml_terra_publica_a USING gist (geom);

ALTER TABLE edgv.lml_terra_publica_a OWNER TO postgres;

ALTER TABLE edgv.lml_terra_publica_a
	 ADD CONSTRAINT lml_terra_publica_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_terra_publica_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.lml_terra_publica_a
	 ADD CONSTRAINT lml_terra_publica_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_terra_publica_a ALTER COLUMN administracao SET DEFAULT 9999;

CREATE TABLE edgv.lml_area_pub_militar_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 codidentificadorunico varchar(50),
	 arealegal real,
	 classificacao varchar(255),
	 administracao smallint NOT NULL,
	 jurisdicao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_area_pub_militar_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_area_pub_militar_a_geom ON edgv.lml_area_pub_militar_a USING gist (geom);

ALTER TABLE edgv.lml_area_pub_militar_a OWNER TO postgres;

ALTER TABLE edgv.lml_area_pub_militar_a
	 ADD CONSTRAINT lml_area_pub_militar_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_area_pub_militar_a
	 ADD CONSTRAINT lml_area_pub_militar_a_administracao_check 
	 CHECK (administracao = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.lml_area_pub_militar_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.lml_area_pub_militar_a
	 ADD CONSTRAINT lml_area_pub_militar_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_area_pub_militar_a
	 ADD CONSTRAINT lml_area_pub_militar_a_jurisdicao_check 
	 CHECK (jurisdicao = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.lml_area_pub_militar_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

CREATE TABLE edgv.lml_area_urbana_isolada_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoassociado smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_area_urbana_isolada_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_area_urbana_isolada_a_geom ON edgv.lml_area_urbana_isolada_a USING gist (geom);

ALTER TABLE edgv.lml_area_urbana_isolada_a OWNER TO postgres;

ALTER TABLE edgv.lml_area_urbana_isolada_a
	 ADD CONSTRAINT lml_area_urbana_isolada_a_tipoassociado_fk FOREIGN KEY (tipoassociado)
	 REFERENCES dominios.tipo_associado (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_area_urbana_isolada_a ALTER COLUMN tipoassociado SET DEFAULT 9999;

CREATE TABLE edgv.lml_nome_local_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT lml_nome_local_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_nome_local_p_geom ON edgv.lml_nome_local_p USING gist (geom);

ALTER TABLE edgv.lml_nome_local_p OWNER TO postgres;

CREATE TABLE edgv.lml_unidade_conservacao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 codidentificadorunico varchar(50),
	 arealegal real,
	 anocriacao varchar(4),
	 historicomodificacoes varchar(255),
	 sigla varchar(255),
	 atolegal varchar(255),
	 areaoficial varchar(15),
	 administracao smallint NOT NULL,
	 classificacao varchar(255),
	 jurisdicao smallint NOT NULL,
	 tipounidprotegida smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT lml_unidade_conservacao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX lml_unidade_conservacao_a_geom ON edgv.lml_unidade_conservacao_a USING gist (geom);

ALTER TABLE edgv.lml_unidade_conservacao_a OWNER TO postgres;

ALTER TABLE edgv.lml_unidade_conservacao_a
	 ADD CONSTRAINT lml_unidade_conservacao_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_conservacao_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.lml_unidade_conservacao_a
	 ADD CONSTRAINT lml_unidade_conservacao_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_conservacao_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.lml_unidade_conservacao_a
	 ADD CONSTRAINT lml_unidade_conservacao_a_tipounidprotegida_fk FOREIGN KEY (tipounidprotegida)
	 REFERENCES dominios.tipo_unid_protegida (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.lml_unidade_conservacao_a
	 ADD CONSTRAINT lml_unidade_conservacao_a_tipounidprotegida_check 
	 CHECK (tipounidprotegida = ANY(ARRAY[4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.lml_unidade_conservacao_a ALTER COLUMN tipounidprotegida SET DEFAULT 9999;

CREATE TABLE edgv.pto_marco_de_limite_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipomarcolim smallint NOT NULL,
	 latitude varchar(16),
	 longitude varchar(16),
	 altitudeortometrica real,
	 sistemageodesico smallint NOT NULL,
	 outrarefplan varchar(255),
	 referencialaltim smallint NOT NULL,
	 outrarefalt varchar(255),
	 codigo varchar(9),
	 orgaoenteresp varchar(255),
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT pto_marco_de_limite_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX pto_marco_de_limite_p_geom ON edgv.pto_marco_de_limite_p USING gist (geom);

ALTER TABLE edgv.pto_marco_de_limite_p OWNER TO postgres;

ALTER TABLE edgv.pto_marco_de_limite_p
	 ADD CONSTRAINT pto_marco_de_limite_p_tipomarcolim_fk FOREIGN KEY (tipomarcolim)
	 REFERENCES dominios.tipo_hierarquia (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_marco_de_limite_p ALTER COLUMN tipomarcolim SET DEFAULT 9999;

ALTER TABLE edgv.pto_marco_de_limite_p
	 ADD CONSTRAINT pto_marco_de_limite_p_sistemageodesico_fk FOREIGN KEY (sistemageodesico)
	 REFERENCES dominios.sistema_geodesico (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_marco_de_limite_p ALTER COLUMN sistemageodesico SET DEFAULT 9999;

ALTER TABLE edgv.pto_marco_de_limite_p
	 ADD CONSTRAINT pto_marco_de_limite_p_referencialaltim_fk FOREIGN KEY (referencialaltim)
	 REFERENCES dominios.referencial_altim (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_marco_de_limite_p ALTER COLUMN referencialaltim SET DEFAULT 9999;

CREATE TABLE edgv.pto_pto_ref_geod_topo_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 tiporef smallint NOT NULL,
	 latitude varchar(16),
	 longitude varchar(16),
	 altitudeortometrica real,
	 altitudegeometrica real,
	 sistemageodesico smallint NOT NULL,
	 outrarefplan varchar(255),
	 referencialaltim smallint NOT NULL,
	 outrarefalt varchar(255),
	 codponto varchar(255),
	 obs varchar(255),
	 nome varchar(255),
	 proximidade smallint NOT NULL,
	 tipoptorefgeodtopo smallint NOT NULL,
	 redereferencia smallint NOT NULL,
	 referencialgrav smallint NOT NULL,
	 situacaomarco smallint NOT NULL,
	 datavisita varchar(10),
	 datamedicao varchar(10),
	 valorgravidade real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT pto_pto_ref_geod_topo_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX pto_pto_ref_geod_topo_p_geom ON edgv.pto_pto_ref_geod_topo_p USING gist (geom);

ALTER TABLE edgv.pto_pto_ref_geod_topo_p OWNER TO postgres;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p
	 ADD CONSTRAINT pto_pto_ref_geod_topo_p_tiporef_fk FOREIGN KEY (tiporef)
	 REFERENCES dominios.tipo_ref (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p ALTER COLUMN tiporef SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p
	 ADD CONSTRAINT pto_pto_ref_geod_topo_p_sistemageodesico_fk FOREIGN KEY (sistemageodesico)
	 REFERENCES dominios.sistema_geodesico (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p ALTER COLUMN sistemageodesico SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p
	 ADD CONSTRAINT pto_pto_ref_geod_topo_p_referencialaltim_fk FOREIGN KEY (referencialaltim)
	 REFERENCES dominios.referencial_altim (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p ALTER COLUMN referencialaltim SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p
	 ADD CONSTRAINT pto_pto_ref_geod_topo_p_proximidade_fk FOREIGN KEY (proximidade)
	 REFERENCES dominios.proximidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p ALTER COLUMN proximidade SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p
	 ADD CONSTRAINT pto_pto_ref_geod_topo_p_tipoptorefgeodtopo_fk FOREIGN KEY (tipoptorefgeodtopo)
	 REFERENCES dominios.tipo_pto_ref_geod_topo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p ALTER COLUMN tipoptorefgeodtopo SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p
	 ADD CONSTRAINT pto_pto_ref_geod_topo_p_redereferencia_fk FOREIGN KEY (redereferencia)
	 REFERENCES dominios.rede_referencia (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p ALTER COLUMN redereferencia SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p
	 ADD CONSTRAINT pto_pto_ref_geod_topo_p_referencialgrav_fk FOREIGN KEY (referencialgrav)
	 REFERENCES dominios.referencial_grav (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p ALTER COLUMN referencialgrav SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p
	 ADD CONSTRAINT pto_pto_ref_geod_topo_p_situacaomarco_fk FOREIGN KEY (situacaomarco)
	 REFERENCES dominios.situacao_marco (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_ref_geod_topo_p ALTER COLUMN situacaomarco SET DEFAULT 9999;

CREATE TABLE edgv.pto_pto_geod_topo_controle_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 tiporef smallint NOT NULL,
	 latitude varchar(16),
	 longitude varchar(16),
	 altitudeortometrica real,
	 altitudegeometrica real,
	 sistemageodesico smallint NOT NULL,
	 outrarefplan varchar(255),
	 referencialaltim smallint NOT NULL,
	 outrarefalt varchar(255),
	 codponto varchar(12),
	 obs varchar(255),
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT pto_pto_geod_topo_controle_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX pto_pto_geod_topo_controle_p_geom ON edgv.pto_pto_geod_topo_controle_p USING gist (geom);

ALTER TABLE edgv.pto_pto_geod_topo_controle_p OWNER TO postgres;

ALTER TABLE edgv.pto_pto_geod_topo_controle_p
	 ADD CONSTRAINT pto_pto_geod_topo_controle_p_tiporef_fk FOREIGN KEY (tiporef)
	 REFERENCES dominios.tipo_ref (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_geod_topo_controle_p ALTER COLUMN tiporef SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_geod_topo_controle_p
	 ADD CONSTRAINT pto_pto_geod_topo_controle_p_sistemageodesico_fk FOREIGN KEY (sistemageodesico)
	 REFERENCES dominios.sistema_geodesico (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_geod_topo_controle_p ALTER COLUMN sistemageodesico SET DEFAULT 9999;

ALTER TABLE edgv.pto_pto_geod_topo_controle_p
	 ADD CONSTRAINT pto_pto_geod_topo_controle_p_referencialaltim_fk FOREIGN KEY (referencialaltim)
	 REFERENCES dominios.referencial_altim (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_geod_topo_controle_p ALTER COLUMN referencialaltim SET DEFAULT 9999;

CREATE TABLE edgv.pto_pto_est_med_fenomenos_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoptoestmed smallint NOT NULL,
	 codestacao varchar(50),
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT pto_pto_est_med_fenomenos_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX pto_pto_est_med_fenomenos_p_geom ON edgv.pto_pto_est_med_fenomenos_p USING gist (geom);

ALTER TABLE edgv.pto_pto_est_med_fenomenos_p OWNER TO postgres;

ALTER TABLE edgv.pto_pto_est_med_fenomenos_p
	 ADD CONSTRAINT pto_pto_est_med_fenomenos_p_tipoptoestmed_fk FOREIGN KEY (tipoptoestmed)
	 REFERENCES dominios.tipo_pto_est_med (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.pto_pto_est_med_fenomenos_p ALTER COLUMN tipoptoestmed SET DEFAULT 9999;

CREATE TABLE edgv.rel_curva_nivel_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 cota integer,
	 depressao boolean NOT NULL,
	 tipocurvanivel smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_curva_nivel_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_curva_nivel_l_geom ON edgv.rel_curva_nivel_l USING gist (geom);

ALTER TABLE edgv.rel_curva_nivel_l OWNER TO postgres;

ALTER TABLE edgv.rel_curva_nivel_l
	 ADD CONSTRAINT rel_curva_nivel_l_tipocurvanivel_fk FOREIGN KEY (tipocurvanivel)
	 REFERENCES dominios.tipo_curva_nivel (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_curva_nivel_l ALTER COLUMN tipocurvanivel SET DEFAULT 9999;

CREATE TABLE edgv.rel_gruta_caverna_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_gruta_caverna_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_gruta_caverna_l_geom ON edgv.rel_gruta_caverna_l USING gist (geom);

ALTER TABLE edgv.rel_gruta_caverna_l OWNER TO postgres;

ALTER TABLE edgv.rel_gruta_caverna_l
	 ADD CONSTRAINT rel_gruta_caverna_l_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_gruta_caverna_l
	 ADD CONSTRAINT rel_gruta_caverna_l_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[15 :: SMALLINT, 20 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_gruta_caverna_l ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_gruta_caverna_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_gruta_caverna_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_gruta_caverna_p_geom ON edgv.rel_gruta_caverna_p USING gist (geom);

ALTER TABLE edgv.rel_gruta_caverna_p OWNER TO postgres;

ALTER TABLE edgv.rel_gruta_caverna_p
	 ADD CONSTRAINT rel_gruta_caverna_p_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_gruta_caverna_p
	 ADD CONSTRAINT rel_gruta_caverna_p_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[15 :: SMALLINT, 20 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_gruta_caverna_p ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_rocha_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 formarocha smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_rocha_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_rocha_l_geom ON edgv.rel_rocha_l USING gist (geom);

ALTER TABLE edgv.rel_rocha_l OWNER TO postgres;

ALTER TABLE edgv.rel_rocha_l
	 ADD CONSTRAINT rel_rocha_l_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_rocha_l
	 ADD CONSTRAINT rel_rocha_l_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[23 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_rocha_l ALTER COLUMN tipoelemnat SET DEFAULT 9999;

ALTER TABLE edgv.rel_rocha_l
	 ADD CONSTRAINT rel_rocha_l_formarocha_fk FOREIGN KEY (formarocha)
	 REFERENCES dominios.forma_rocha (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_rocha_l ALTER COLUMN formarocha SET DEFAULT 9999;

CREATE TABLE edgv.rel_rocha_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 formarocha smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_rocha_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_rocha_p_geom ON edgv.rel_rocha_p USING gist (geom);

ALTER TABLE edgv.rel_rocha_p OWNER TO postgres;

ALTER TABLE edgv.rel_rocha_p
	 ADD CONSTRAINT rel_rocha_p_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_rocha_p
	 ADD CONSTRAINT rel_rocha_p_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[23 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_rocha_p ALTER COLUMN tipoelemnat SET DEFAULT 9999;

ALTER TABLE edgv.rel_rocha_p
	 ADD CONSTRAINT rel_rocha_p_formarocha_fk FOREIGN KEY (formarocha)
	 REFERENCES dominios.forma_rocha (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_rocha_p ALTER COLUMN formarocha SET DEFAULT 9999;

CREATE TABLE edgv.rel_rocha_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 formarocha smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rel_rocha_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_rocha_a_geom ON edgv.rel_rocha_a USING gist (geom);

ALTER TABLE edgv.rel_rocha_a OWNER TO postgres;

ALTER TABLE edgv.rel_rocha_a
	 ADD CONSTRAINT rel_rocha_a_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_rocha_a
	 ADD CONSTRAINT rel_rocha_a_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[23 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_rocha_a ALTER COLUMN tipoelemnat SET DEFAULT 9999;

ALTER TABLE edgv.rel_rocha_a
	 ADD CONSTRAINT rel_rocha_a_formarocha_fk FOREIGN KEY (formarocha)
	 REFERENCES dominios.forma_rocha (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_rocha_a ALTER COLUMN formarocha SET DEFAULT 9999;

CREATE TABLE edgv.rel_corte_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_corte_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_corte_l_geom ON edgv.rel_corte_l USING gist (geom);

ALTER TABLE edgv.rel_corte_l OWNER TO postgres;

ALTER TABLE edgv.rel_corte_l
	 ADD CONSTRAINT rel_corte_l_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_corte_l
	 ADD CONSTRAINT rel_corte_l_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[26 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_corte_l ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.rel_corte_l
	 ADD CONSTRAINT rel_corte_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_corte_l
	 ADD CONSTRAINT rel_corte_l_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 23 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_corte_l ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.rel_corte_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_corte_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_corte_p_geom ON edgv.rel_corte_p USING gist (geom);

ALTER TABLE edgv.rel_corte_p OWNER TO postgres;

ALTER TABLE edgv.rel_corte_p
	 ADD CONSTRAINT rel_corte_p_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_corte_p
	 ADD CONSTRAINT rel_corte_p_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[26 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_corte_p ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.rel_corte_p
	 ADD CONSTRAINT rel_corte_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_corte_p
	 ADD CONSTRAINT rel_corte_p_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 23 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_corte_p ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.rel_corte_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rel_corte_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_corte_a_geom ON edgv.rel_corte_a USING gist (geom);

ALTER TABLE edgv.rel_corte_a OWNER TO postgres;

ALTER TABLE edgv.rel_corte_a
	 ADD CONSTRAINT rel_corte_a_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_corte_a
	 ADD CONSTRAINT rel_corte_a_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[26 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_corte_a ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.rel_corte_a
	 ADD CONSTRAINT rel_corte_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_corte_a
	 ADD CONSTRAINT rel_corte_a_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 23 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_corte_a ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.rel_terreno_exposto_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 tipoterrexp smallint NOT NULL,
	 causaexposicao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rel_terreno_exposto_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_terreno_exposto_a_geom ON edgv.rel_terreno_exposto_a USING gist (geom);

ALTER TABLE edgv.rel_terreno_exposto_a OWNER TO postgres;

ALTER TABLE edgv.rel_terreno_exposto_a
	 ADD CONSTRAINT rel_terreno_exposto_a_tipoterrexp_fk FOREIGN KEY (tipoterrexp)
	 REFERENCES dominios.tipo_terreno_exposto (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_terreno_exposto_a ALTER COLUMN tipoterrexp SET DEFAULT 9999;

ALTER TABLE edgv.rel_terreno_exposto_a
	 ADD CONSTRAINT rel_terreno_exposto_a_causaexposicao_fk FOREIGN KEY (causaexposicao)
	 REFERENCES dominios.causa_exposicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_terreno_exposto_a ALTER COLUMN causaexposicao SET DEFAULT 9999;

CREATE TABLE edgv.rel_dolina_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_dolina_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_dolina_p_geom ON edgv.rel_dolina_p USING gist (geom);

ALTER TABLE edgv.rel_dolina_p OWNER TO postgres;

ALTER TABLE edgv.rel_dolina_p
	 ADD CONSTRAINT rel_dolina_p_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_dolina_p
	 ADD CONSTRAINT rel_dolina_p_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[16 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_dolina_p ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_dolina_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rel_dolina_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_dolina_a_geom ON edgv.rel_dolina_a USING gist (geom);

ALTER TABLE edgv.rel_dolina_a OWNER TO postgres;

ALTER TABLE edgv.rel_dolina_a
	 ADD CONSTRAINT rel_dolina_a_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_dolina_a
	 ADD CONSTRAINT rel_dolina_a_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[16 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_dolina_a ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_aterro_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_aterro_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_aterro_l_geom ON edgv.rel_aterro_l USING gist (geom);

ALTER TABLE edgv.rel_aterro_l OWNER TO postgres;

ALTER TABLE edgv.rel_aterro_l
	 ADD CONSTRAINT rel_aterro_l_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_aterro_l
	 ADD CONSTRAINT rel_aterro_l_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[27 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_aterro_l ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.rel_aterro_l
	 ADD CONSTRAINT rel_aterro_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_aterro_l
	 ADD CONSTRAINT rel_aterro_l_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 23 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_aterro_l ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.rel_aterro_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_aterro_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_aterro_p_geom ON edgv.rel_aterro_p USING gist (geom);

ALTER TABLE edgv.rel_aterro_p OWNER TO postgres;

ALTER TABLE edgv.rel_aterro_p
	 ADD CONSTRAINT rel_aterro_p_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_aterro_p
	 ADD CONSTRAINT rel_aterro_p_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[27 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_aterro_p ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.rel_aterro_p
	 ADD CONSTRAINT rel_aterro_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_aterro_p
	 ADD CONSTRAINT rel_aterro_p_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 23 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_aterro_p ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.rel_aterro_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rel_aterro_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_aterro_a_geom ON edgv.rel_aterro_a USING gist (geom);

ALTER TABLE edgv.rel_aterro_a OWNER TO postgres;

ALTER TABLE edgv.rel_aterro_a
	 ADD CONSTRAINT rel_aterro_a_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_aterro_a
	 ADD CONSTRAINT rel_aterro_a_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[27 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_aterro_a ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

ALTER TABLE edgv.rel_aterro_a
	 ADD CONSTRAINT rel_aterro_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_aterro_a
	 ADD CONSTRAINT rel_aterro_a_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 23 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_aterro_a ALTER COLUMN matconstr SET DEFAULT 9999;

CREATE TABLE edgv.rel_ponto_cotado_altimetrico_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 cotacomprovada boolean NOT NULL,
	 cota real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_ponto_cotado_altimetrico_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_ponto_cotado_altimetrico_p_geom ON edgv.rel_ponto_cotado_altimetrico_p USING gist (geom);

ALTER TABLE edgv.rel_ponto_cotado_altimetrico_p OWNER TO postgres;

CREATE TABLE edgv.rel_elemento_fisiografico_natural_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_elemento_fisiografico_natural_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_elemento_fisiografico_natural_l_geom ON edgv.rel_elemento_fisiografico_natural_l USING gist (geom);

ALTER TABLE edgv.rel_elemento_fisiografico_natural_l OWNER TO postgres;

ALTER TABLE edgv.rel_elemento_fisiografico_natural_l
	 ADD CONSTRAINT rel_elemento_fisiografico_natural_l_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_elemento_fisiografico_natural_l
	 ADD CONSTRAINT rel_elemento_fisiografico_natural_l_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 8 :: SMALLINT, 9 :: SMALLINT, 10 :: SMALLINT, 11 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 14 :: SMALLINT, 18 :: SMALLINT, 19 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_elemento_fisiografico_natural_l ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_elemento_fisiografico_natural_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_elemento_fisiografico_natural_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_elemento_fisiografico_natural_p_geom ON edgv.rel_elemento_fisiografico_natural_p USING gist (geom);

ALTER TABLE edgv.rel_elemento_fisiografico_natural_p OWNER TO postgres;

ALTER TABLE edgv.rel_elemento_fisiografico_natural_p
	 ADD CONSTRAINT rel_elemento_fisiografico_natural_p_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_elemento_fisiografico_natural_p
	 ADD CONSTRAINT rel_elemento_fisiografico_natural_p_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 8 :: SMALLINT, 9 :: SMALLINT, 10 :: SMALLINT, 11 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 14 :: SMALLINT, 18 :: SMALLINT, 19 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_elemento_fisiografico_natural_p ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_elemento_fisiografico_natural_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rel_elemento_fisiografico_natural_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_elemento_fisiografico_natural_a_geom ON edgv.rel_elemento_fisiografico_natural_a USING gist (geom);

ALTER TABLE edgv.rel_elemento_fisiografico_natural_a OWNER TO postgres;

ALTER TABLE edgv.rel_elemento_fisiografico_natural_a
	 ADD CONSTRAINT rel_elemento_fisiografico_natural_a_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_elemento_fisiografico_natural_a
	 ADD CONSTRAINT rel_elemento_fisiografico_natural_a_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 8 :: SMALLINT, 9 :: SMALLINT, 10 :: SMALLINT, 11 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 14 :: SMALLINT, 18 :: SMALLINT, 19 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_elemento_fisiografico_natural_a ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_pico_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_pico_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_pico_p_geom ON edgv.rel_pico_p USING gist (geom);

ALTER TABLE edgv.rel_pico_p OWNER TO postgres;

ALTER TABLE edgv.rel_pico_p
	 ADD CONSTRAINT rel_pico_p_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_pico_p
	 ADD CONSTRAINT rel_pico_p_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[22 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_pico_p ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_duna_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 fixa boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_duna_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_duna_l_geom ON edgv.rel_duna_l USING gist (geom);

ALTER TABLE edgv.rel_duna_l OWNER TO postgres;

ALTER TABLE edgv.rel_duna_l
	 ADD CONSTRAINT rel_duna_l_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_duna_l
	 ADD CONSTRAINT rel_duna_l_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[17 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_duna_l ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_duna_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 fixa boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_duna_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_duna_p_geom ON edgv.rel_duna_p USING gist (geom);

ALTER TABLE edgv.rel_duna_p OWNER TO postgres;

ALTER TABLE edgv.rel_duna_p
	 ADD CONSTRAINT rel_duna_p_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_duna_p
	 ADD CONSTRAINT rel_duna_p_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[17 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_duna_p ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_duna_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoelemnat smallint NOT NULL,
	 fixa boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rel_duna_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_duna_a_geom ON edgv.rel_duna_a USING gist (geom);

ALTER TABLE edgv.rel_duna_a OWNER TO postgres;

ALTER TABLE edgv.rel_duna_a
	 ADD CONSTRAINT rel_duna_a_tipoelemnat_fk FOREIGN KEY (tipoelemnat)
	 REFERENCES dominios.tipo_elem_nat (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_duna_a
	 ADD CONSTRAINT rel_duna_a_tipoelemnat_check 
	 CHECK (tipoelemnat = ANY(ARRAY[17 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_duna_a ALTER COLUMN tipoelemnat SET DEFAULT 9999;

CREATE TABLE edgv.rel_curva_batimetrica_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 profundidade integer,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_curva_batimetrica_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_curva_batimetrica_l_geom ON edgv.rel_curva_batimetrica_l USING gist (geom);

ALTER TABLE edgv.rel_curva_batimetrica_l OWNER TO postgres;

CREATE TABLE edgv.rel_alteracao_fisiografica_antropica_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rel_alteracao_fisiografica_antropica_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_alteracao_fisiografica_antropica_l_geom ON edgv.rel_alteracao_fisiografica_antropica_l USING gist (geom);

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_l OWNER TO postgres;

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_l
	 ADD CONSTRAINT rel_alteracao_fisiografica_antropica_l_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_l
	 ADD CONSTRAINT rel_alteracao_fisiografica_antropica_l_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[0 :: SMALLINT, 24 :: SMALLINT, 28 :: SMALLINT, 29 :: SMALLINT, 32 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_l ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

CREATE TABLE edgv.rel_alteracao_fisiografica_antropica_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_alteracao_fisiografica_antropica_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_alteracao_fisiografica_antropica_p_geom ON edgv.rel_alteracao_fisiografica_antropica_p USING gist (geom);

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_p OWNER TO postgres;

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_p
	 ADD CONSTRAINT rel_alteracao_fisiografica_antropica_p_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_p
	 ADD CONSTRAINT rel_alteracao_fisiografica_antropica_p_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[0 :: SMALLINT, 24 :: SMALLINT, 28 :: SMALLINT, 29 :: SMALLINT, 32 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_p ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

CREATE TABLE edgv.rel_alteracao_fisiografica_antropica_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoalterantrop smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rel_alteracao_fisiografica_antropica_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_alteracao_fisiografica_antropica_a_geom ON edgv.rel_alteracao_fisiografica_antropica_a USING gist (geom);

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_a OWNER TO postgres;

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_a
	 ADD CONSTRAINT rel_alteracao_fisiografica_antropica_a_tipoalterantrop_fk FOREIGN KEY (tipoalterantrop)
	 REFERENCES dominios.tipo_alter_antrop (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_a
	 ADD CONSTRAINT rel_alteracao_fisiografica_antropica_a_tipoalterantrop_check 
	 CHECK (tipoalterantrop = ANY(ARRAY[0 :: SMALLINT, 24 :: SMALLINT, 28 :: SMALLINT, 29 :: SMALLINT, 32 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rel_alteracao_fisiografica_antropica_a ALTER COLUMN tipoalterantrop SET DEFAULT 9999;

CREATE TABLE edgv.rel_ponto_cotado_batimetrico_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 profundidade real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT rel_ponto_cotado_batimetrico_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rel_ponto_cotado_batimetrico_p_geom ON edgv.rel_ponto_cotado_batimetrico_p USING gist (geom);

ALTER TABLE edgv.rel_ponto_cotado_batimetrico_p OWNER TO postgres;

CREATE TABLE edgv.rod_trecho_rodoviario_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 jurisdicao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 concessionaria varchar(255),
	 revestimento smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 canteirodivisorio smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 trafego smallint NOT NULL,
	 tipopavimentacao smallint NOT NULL,
	 tipovia smallint NOT NULL,
	 sigla varchar(255),
	 codtrechorod varchar(25),
	 limitevelocidade real,
	 trechoemperimetrourbano smallint NOT NULL,
	 acostamento smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT rod_trecho_rodoviario_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rod_trecho_rodoviario_l_geom ON edgv.rod_trecho_rodoviario_l USING gist (geom);

ALTER TABLE edgv.rod_trecho_rodoviario_l OWNER TO postgres;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_revestimento_fk FOREIGN KEY (revestimento)
	 REFERENCES dominios.revestimento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN revestimento SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_canteirodivisorio_fk FOREIGN KEY (canteirodivisorio)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN canteirodivisorio SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_trafego_fk FOREIGN KEY (trafego)
	 REFERENCES dominios.trafego (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN trafego SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_tipovia_fk FOREIGN KEY (tipovia)
	 REFERENCES dominios.tipo_via (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_tipovia_check 
	 CHECK (tipovia = ANY(ARRAY[2 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN tipovia SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_trechoemperimetrourbano_fk FOREIGN KEY (trechoemperimetrourbano)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN trechoemperimetrourbano SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_l
	 ADD CONSTRAINT rod_trecho_rodoviario_l_acostamento_fk FOREIGN KEY (acostamento)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_l ALTER COLUMN acostamento SET DEFAULT 9999;

CREATE TABLE edgv.rod_trecho_rodoviario_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 jurisdicao smallint NOT NULL,
	 administracao smallint NOT NULL,
	 concessionaria varchar(255),
	 revestimento smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 canteirodivisorio smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 trafego smallint NOT NULL,
	 tipopavimentacao smallint NOT NULL,
	 tipovia smallint NOT NULL,
	 sigla varchar(255),
	 codtrechorod varchar(25),
	 limitevelocidade real,
	 trechoemperimetrourbano smallint NOT NULL,
	 acostamento smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT rod_trecho_rodoviario_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX rod_trecho_rodoviario_a_geom ON edgv.rod_trecho_rodoviario_a USING gist (geom);

ALTER TABLE edgv.rod_trecho_rodoviario_a OWNER TO postgres;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_jurisdicao_fk FOREIGN KEY (jurisdicao)
	 REFERENCES dominios.jurisdicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN jurisdicao SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_revestimento_fk FOREIGN KEY (revestimento)
	 REFERENCES dominios.revestimento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN revestimento SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_canteirodivisorio_fk FOREIGN KEY (canteirodivisorio)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN canteirodivisorio SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_trafego_fk FOREIGN KEY (trafego)
	 REFERENCES dominios.trafego (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN trafego SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_tipovia_fk FOREIGN KEY (tipovia)
	 REFERENCES dominios.tipo_via (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_tipovia_check 
	 CHECK (tipovia = ANY(ARRAY[2 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN tipovia SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_trechoemperimetrourbano_fk FOREIGN KEY (trechoemperimetrourbano)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN trechoemperimetrourbano SET DEFAULT 9999;

ALTER TABLE edgv.rod_trecho_rodoviario_a
	 ADD CONSTRAINT rod_trecho_rodoviario_a_acostamento_fk FOREIGN KEY (acostamento)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.rod_trecho_rodoviario_a ALTER COLUMN acostamento SET DEFAULT 9999;

CREATE TABLE edgv.snb_dep_abast_agua_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipodepgeral smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 tipoexposicao smallint NOT NULL,
	 tipoprodutoresiduo smallint NOT NULL,
	 tipoconteudo smallint NOT NULL,
	 unidadevolume smallint NOT NULL,
	 valorvolume real,
	 tratamento smallint NOT NULL,
	 estadofisico smallint NOT NULL,
	 finalidadedep smallint NOT NULL,
	 situacaoagua smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT snb_dep_abast_agua_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX snb_dep_abast_agua_p_geom ON edgv.snb_dep_abast_agua_p USING gist (geom);

ALTER TABLE edgv.snb_dep_abast_agua_p OWNER TO postgres;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_tipodepgeral_fk FOREIGN KEY (tipodepgeral)
	 REFERENCES dominios.tipo_dep_geral (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_tipodepgeral_check 
	 CHECK (tipodepgeral = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 19 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN tipodepgeral SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_tipoexposicao_fk FOREIGN KEY (tipoexposicao)
	 REFERENCES dominios.tipo_exposicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN tipoexposicao SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_tipoprodutoresiduo_fk FOREIGN KEY (tipoprodutoresiduo)
	 REFERENCES dominios.tipo_produto_residuo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_tipoprodutoresiduo_check 
	 CHECK (tipoprodutoresiduo = ANY(ARRAY[46 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN tipoprodutoresiduo SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_tipoconteudo_fk FOREIGN KEY (tipoconteudo)
	 REFERENCES dominios.tipo_conteudo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN tipoconteudo SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_unidadevolume_fk FOREIGN KEY (unidadevolume)
	 REFERENCES dominios.unidade_volume (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN unidadevolume SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_tratamento_fk FOREIGN KEY (tratamento)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN tratamento SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_estadofisico_fk FOREIGN KEY (estadofisico)
	 REFERENCES dominios.estado_fisico (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_estadofisico_check 
	 CHECK (estadofisico = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN estadofisico SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_finalidadedep_fk FOREIGN KEY (finalidadedep)
	 REFERENCES dominios.finalidade_deposito (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN finalidadedep SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_p
	 ADD CONSTRAINT snb_dep_abast_agua_p_situacaoagua_fk FOREIGN KEY (situacaoagua)
	 REFERENCES dominios.situacao_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_p ALTER COLUMN situacaoagua SET DEFAULT 9999;

CREATE TABLE edgv.snb_dep_abast_agua_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 tipodepgeral smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 tipoexposicao smallint NOT NULL,
	 tipoprodutoresiduo smallint NOT NULL,
	 tipoconteudo smallint NOT NULL,
	 unidadevolume smallint NOT NULL,
	 valorvolume real,
	 tratamento smallint NOT NULL,
	 estadofisico smallint NOT NULL,
	 finalidadedep smallint NOT NULL,
	 situacaoagua smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT snb_dep_abast_agua_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX snb_dep_abast_agua_a_geom ON edgv.snb_dep_abast_agua_a USING gist (geom);

ALTER TABLE edgv.snb_dep_abast_agua_a OWNER TO postgres;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_tipodepgeral_fk FOREIGN KEY (tipodepgeral)
	 REFERENCES dominios.tipo_dep_geral (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_tipodepgeral_check 
	 CHECK (tipodepgeral = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 19 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN tipodepgeral SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_tipoexposicao_fk FOREIGN KEY (tipoexposicao)
	 REFERENCES dominios.tipo_exposicao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN tipoexposicao SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_tipoprodutoresiduo_fk FOREIGN KEY (tipoprodutoresiduo)
	 REFERENCES dominios.tipo_produto_residuo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_tipoprodutoresiduo_check 
	 CHECK (tipoprodutoresiduo = ANY(ARRAY[46 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN tipoprodutoresiduo SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_tipoconteudo_fk FOREIGN KEY (tipoconteudo)
	 REFERENCES dominios.tipo_conteudo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN tipoconteudo SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_unidadevolume_fk FOREIGN KEY (unidadevolume)
	 REFERENCES dominios.unidade_volume (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN unidadevolume SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_tratamento_fk FOREIGN KEY (tratamento)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN tratamento SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_estadofisico_fk FOREIGN KEY (estadofisico)
	 REFERENCES dominios.estado_fisico (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_estadofisico_check 
	 CHECK (estadofisico = ANY(ARRAY[1 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN estadofisico SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_finalidadedep_fk FOREIGN KEY (finalidadedep)
	 REFERENCES dominios.finalidade_deposito (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN finalidadedep SET DEFAULT 9999;

ALTER TABLE edgv.snb_dep_abast_agua_a
	 ADD CONSTRAINT snb_dep_abast_agua_a_situacaoagua_fk FOREIGN KEY (situacaoagua)
	 REFERENCES dominios.situacao_agua (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_dep_abast_agua_a ALTER COLUMN situacaoagua SET DEFAULT 9999;

CREATE TABLE edgv.snb_barragem_calcadao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoequipdesenvsocial smallint NOT NULL,
	 sigla varchar(255),
	 codequipdesenvsocial varchar(255),
	 localizacaoequipdesenvsocial smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT snb_barragem_calcadao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX snb_barragem_calcadao_a_geom ON edgv.snb_barragem_calcadao_a USING gist (geom);

ALTER TABLE edgv.snb_barragem_calcadao_a OWNER TO postgres;

ALTER TABLE edgv.snb_barragem_calcadao_a
	 ADD CONSTRAINT snb_barragem_calcadao_a_tipoequipdesenvsocial_fk FOREIGN KEY (tipoequipdesenvsocial)
	 REFERENCES dominios.tipo_equip_desenv_social (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_barragem_calcadao_a
	 ADD CONSTRAINT snb_barragem_calcadao_a_tipoequipdesenvsocial_check 
	 CHECK (tipoequipdesenvsocial = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.snb_barragem_calcadao_a ALTER COLUMN tipoequipdesenvsocial SET DEFAULT 9999;

ALTER TABLE edgv.snb_barragem_calcadao_a
	 ADD CONSTRAINT snb_barragem_calcadao_a_localizacaoequipdesenvsocial_fk FOREIGN KEY (localizacaoequipdesenvsocial)
	 REFERENCES dominios.local_equip_desenv_social (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.snb_barragem_calcadao_a ALTER COLUMN localizacaoequipdesenvsocial SET DEFAULT 9999;

CREATE TABLE edgv.tra_entroncamento_pto_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipoentroncamento smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT tra_entroncamento_pto_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_entroncamento_pto_p_geom ON edgv.tra_entroncamento_pto_p USING gist (geom);

ALTER TABLE edgv.tra_entroncamento_pto_p OWNER TO postgres;

ALTER TABLE edgv.tra_entroncamento_pto_p
	 ADD CONSTRAINT tra_entroncamento_pto_p_tipoentroncamento_fk FOREIGN KEY (tipoentroncamento)
	 REFERENCES dominios.tipo_entroncamento (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_entroncamento_pto_p ALTER COLUMN tipoentroncamento SET DEFAULT 9999;

CREATE TABLE edgv.tra_funicular_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_funicular_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_funicular_l_geom ON edgv.tra_funicular_l USING gist (geom);

ALTER TABLE edgv.tra_funicular_l OWNER TO postgres;

ALTER TABLE edgv.tra_funicular_l
	 ADD CONSTRAINT tra_funicular_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_funicular_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_funicular_l
	 ADD CONSTRAINT tra_funicular_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_funicular_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.tra_ponte_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 tipoponte smallint NOT NULL,
	 vaolivrehoriz real,
	 vaovertical real,
	 cargasuportmaxima real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_ponte_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_ponte_l_geom ON edgv.tra_ponte_l USING gist (geom);

ALTER TABLE edgv.tra_ponte_l OWNER TO postgres;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_ponte_l ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_ponte_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_l ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_l ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_l ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_l
	 ADD CONSTRAINT tra_ponte_l_tipoponte_fk FOREIGN KEY (tipoponte)
	 REFERENCES dominios.tipo_ponte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_l ALTER COLUMN tipoponte SET DEFAULT 9999;

CREATE TABLE edgv.tra_ponte_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 tipoponte smallint NOT NULL,
	 vaolivrehoriz real,
	 vaovertical real,
	 cargasuportmaxima real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT tra_ponte_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_ponte_p_geom ON edgv.tra_ponte_p USING gist (geom);

ALTER TABLE edgv.tra_ponte_p OWNER TO postgres;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_ponte_p ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_ponte_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_p ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_p ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_p ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_p
	 ADD CONSTRAINT tra_ponte_p_tipoponte_fk FOREIGN KEY (tipoponte)
	 REFERENCES dominios.tipo_ponte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_p ALTER COLUMN tipoponte SET DEFAULT 9999;

CREATE TABLE edgv.tra_ponte_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 tipoponte smallint NOT NULL,
	 vaolivrehoriz real,
	 vaovertical real,
	 cargasuportmaxima real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT tra_ponte_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_ponte_a_geom ON edgv.tra_ponte_a USING gist (geom);

ALTER TABLE edgv.tra_ponte_a OWNER TO postgres;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_ponte_a ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_matconstr_check 
	 CHECK (matconstr = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_ponte_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_a ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_a ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_a ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_ponte_a
	 ADD CONSTRAINT tra_ponte_a_tipoponte_fk FOREIGN KEY (tipoponte)
	 REFERENCES dominios.tipo_ponte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_ponte_a ALTER COLUMN tipoponte SET DEFAULT 9999;

CREATE TABLE edgv.tra_caminho_aereo_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipocaminhoaereo smallint NOT NULL,
	 tipousocaminhoaer smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_caminho_aereo_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_caminho_aereo_l_geom ON edgv.tra_caminho_aereo_l USING gist (geom);

ALTER TABLE edgv.tra_caminho_aereo_l OWNER TO postgres;

ALTER TABLE edgv.tra_caminho_aereo_l
	 ADD CONSTRAINT tra_caminho_aereo_l_tipocaminhoaereo_fk FOREIGN KEY (tipocaminhoaereo)
	 REFERENCES dominios.tipo_caminho_aereo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_caminho_aereo_l ALTER COLUMN tipocaminhoaereo SET DEFAULT 9999;

ALTER TABLE edgv.tra_caminho_aereo_l
	 ADD CONSTRAINT tra_caminho_aereo_l_tipousocaminhoaer_fk FOREIGN KEY (tipousocaminhoaer)
	 REFERENCES dominios.tipo_transporte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_caminho_aereo_l ALTER COLUMN tipousocaminhoaer SET DEFAULT 9999;

ALTER TABLE edgv.tra_caminho_aereo_l
	 ADD CONSTRAINT tra_caminho_aereo_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_caminho_aereo_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_caminho_aereo_l
	 ADD CONSTRAINT tra_caminho_aereo_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_caminho_aereo_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

CREATE TABLE edgv.tra_trilha_picada_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_trilha_picada_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_trilha_picada_l_geom ON edgv.tra_trilha_picada_l USING gist (geom);

ALTER TABLE edgv.tra_trilha_picada_l OWNER TO postgres;

CREATE TABLE edgv.tra_passagem_nivel_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT tra_passagem_nivel_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_passagem_nivel_p_geom ON edgv.tra_passagem_nivel_p USING gist (geom);

ALTER TABLE edgv.tra_passagem_nivel_p OWNER TO postgres;

CREATE TABLE edgv.tra_travessia_pedestre_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 tipotravessiaped smallint NOT NULL,
	 extensao real,
	 largura real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_travessia_pedestre_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_travessia_pedestre_l_geom ON edgv.tra_travessia_pedestre_l USING gist (geom);

ALTER TABLE edgv.tra_travessia_pedestre_l OWNER TO postgres;

ALTER TABLE edgv.tra_travessia_pedestre_l
	 ADD CONSTRAINT tra_travessia_pedestre_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_l
	 ADD CONSTRAINT tra_travessia_pedestre_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_l
	 ADD CONSTRAINT tra_travessia_pedestre_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_l
	 ADD CONSTRAINT tra_travessia_pedestre_l_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_l ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_l
	 ADD CONSTRAINT tra_travessia_pedestre_l_tipotravessiaped_fk FOREIGN KEY (tipotravessiaped)
	 REFERENCES dominios.tipo_travessia_ped (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_l ALTER COLUMN tipotravessiaped SET DEFAULT 9999;

CREATE TABLE edgv.tra_travessia_pedestre_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 tipotravessiaped smallint NOT NULL,
	 extensao real,
	 largura real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT tra_travessia_pedestre_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_travessia_pedestre_p_geom ON edgv.tra_travessia_pedestre_p USING gist (geom);

ALTER TABLE edgv.tra_travessia_pedestre_p OWNER TO postgres;

ALTER TABLE edgv.tra_travessia_pedestre_p
	 ADD CONSTRAINT tra_travessia_pedestre_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_p
	 ADD CONSTRAINT tra_travessia_pedestre_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_p
	 ADD CONSTRAINT tra_travessia_pedestre_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_p
	 ADD CONSTRAINT tra_travessia_pedestre_p_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_p ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_p
	 ADD CONSTRAINT tra_travessia_pedestre_p_tipotravessiaped_fk FOREIGN KEY (tipotravessiaped)
	 REFERENCES dominios.tipo_travessia_ped (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_p ALTER COLUMN tipotravessiaped SET DEFAULT 9999;

CREATE TABLE edgv.tra_travessia_pedestre_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 situacaoespacial smallint NOT NULL,
	 tipotravessiaped smallint NOT NULL,
	 extensao real,
	 largura real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT tra_travessia_pedestre_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_travessia_pedestre_a_geom ON edgv.tra_travessia_pedestre_a USING gist (geom);

ALTER TABLE edgv.tra_travessia_pedestre_a OWNER TO postgres;

ALTER TABLE edgv.tra_travessia_pedestre_a
	 ADD CONSTRAINT tra_travessia_pedestre_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_a
	 ADD CONSTRAINT tra_travessia_pedestre_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_a
	 ADD CONSTRAINT tra_travessia_pedestre_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_a
	 ADD CONSTRAINT tra_travessia_pedestre_a_situacaoespacial_fk FOREIGN KEY (situacaoespacial)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_a ALTER COLUMN situacaoespacial SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_pedestre_a
	 ADD CONSTRAINT tra_travessia_pedestre_a_tipotravessiaped_fk FOREIGN KEY (tipotravessiaped)
	 REFERENCES dominios.tipo_travessia_ped (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_pedestre_a ALTER COLUMN tipotravessiaped SET DEFAULT 9999;

CREATE TABLE edgv.tra_travessia_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipotravessia smallint NOT NULL,
	 tipouso smallint NOT NULL,
	 tipoembarcacao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_travessia_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_travessia_l_geom ON edgv.tra_travessia_l USING gist (geom);

ALTER TABLE edgv.tra_travessia_l OWNER TO postgres;

ALTER TABLE edgv.tra_travessia_l
	 ADD CONSTRAINT tra_travessia_l_tipotravessia_fk FOREIGN KEY (tipotravessia)
	 REFERENCES dominios.tipo_travessia (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_l ALTER COLUMN tipotravessia SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_l
	 ADD CONSTRAINT tra_travessia_l_tipouso_fk FOREIGN KEY (tipouso)
	 REFERENCES dominios.tipo_transporte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_l ALTER COLUMN tipouso SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_l
	 ADD CONSTRAINT tra_travessia_l_tipoembarcacao_fk FOREIGN KEY (tipoembarcacao)
	 REFERENCES dominios.tipo_embarcacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_l ALTER COLUMN tipoembarcacao SET DEFAULT 9999;

CREATE TABLE edgv.tra_travessia_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 tipotravessia smallint NOT NULL,
	 tipouso smallint NOT NULL,
	 tipoembarcacao smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT tra_travessia_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_travessia_p_geom ON edgv.tra_travessia_p USING gist (geom);

ALTER TABLE edgv.tra_travessia_p OWNER TO postgres;

ALTER TABLE edgv.tra_travessia_p
	 ADD CONSTRAINT tra_travessia_p_tipotravessia_fk FOREIGN KEY (tipotravessia)
	 REFERENCES dominios.tipo_travessia (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_p ALTER COLUMN tipotravessia SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_p
	 ADD CONSTRAINT tra_travessia_p_tipouso_fk FOREIGN KEY (tipouso)
	 REFERENCES dominios.tipo_transporte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_p ALTER COLUMN tipouso SET DEFAULT 9999;

ALTER TABLE edgv.tra_travessia_p
	 ADD CONSTRAINT tra_travessia_p_tipoembarcacao_fk FOREIGN KEY (tipoembarcacao)
	 REFERENCES dominios.tipo_embarcacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_travessia_p ALTER COLUMN tipoembarcacao SET DEFAULT 9999;

CREATE TABLE edgv.tra_caminho_carrocavel_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_caminho_carrocavel_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_caminho_carrocavel_l_geom ON edgv.tra_caminho_carrocavel_l USING gist (geom);

ALTER TABLE edgv.tra_caminho_carrocavel_l OWNER TO postgres;

CREATE TABLE edgv.tra_tunel_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 altura real,
	 tipotunel smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_tunel_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_tunel_l_geom ON edgv.tra_tunel_l USING gist (geom);

ALTER TABLE edgv.tra_tunel_l OWNER TO postgres;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_tunel_l ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_l ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_posicaopista_check 
	 CHECK (posicaopista = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_tunel_l ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_l ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_l
	 ADD CONSTRAINT tra_tunel_l_tipotunel_fk FOREIGN KEY (tipotunel)
	 REFERENCES dominios.tipo_tunel (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_l ALTER COLUMN tipotunel SET DEFAULT 9999;

CREATE TABLE edgv.tra_tunel_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 altura real,
	 tipotunel smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT tra_tunel_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_tunel_p_geom ON edgv.tra_tunel_p USING gist (geom);

ALTER TABLE edgv.tra_tunel_p OWNER TO postgres;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_tunel_p ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_p ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_posicaopista_check 
	 CHECK (posicaopista = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_tunel_p ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_p ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_p
	 ADD CONSTRAINT tra_tunel_p_tipotunel_fk FOREIGN KEY (tipotunel)
	 REFERENCES dominios.tipo_tunel (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_p ALTER COLUMN tipotunel SET DEFAULT 9999;

CREATE TABLE edgv.tra_tunel_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 altura real,
	 tipotunel smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT tra_tunel_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_tunel_a_geom ON edgv.tra_tunel_a USING gist (geom);

ALTER TABLE edgv.tra_tunel_a OWNER TO postgres;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_tunel_a ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_a ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_posicaopista_check 
	 CHECK (posicaopista = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_tunel_a ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_a ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_tunel_a
	 ADD CONSTRAINT tra_tunel_a_tipotunel_fk FOREIGN KEY (tipotunel)
	 REFERENCES dominios.tipo_tunel (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_tunel_a ALTER COLUMN tipotunel SET DEFAULT 9999;

CREATE TABLE edgv.tra_passagem_elevada_viaduto_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 tipopassagviad smallint NOT NULL,
	 vaolivrehoriz real,
	 vaovertical real,
	 gabhorizsup real,
	 gabvertsup real,
	 cargasuportmaxima real,
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT tra_passagem_elevada_viaduto_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_passagem_elevada_viaduto_l_geom ON edgv.tra_passagem_elevada_viaduto_l USING gist (geom);

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l OWNER TO postgres;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_posicaopista_check 
	 CHECK (posicaopista = ANY(ARRAY[0 :: SMALLINT, 4 :: SMALLINT, 7 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 97 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_l_tipopassagviad_fk FOREIGN KEY (tipopassagviad)
	 REFERENCES dominios.tipo_passag_viad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_l ALTER COLUMN tipopassagviad SET DEFAULT 9999;

CREATE TABLE edgv.tra_passagem_elevada_viaduto_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 tipopassagviad smallint NOT NULL,
	 vaolivrehoriz real,
	 vaovertical real,
	 gabhorizsup real,
	 gabvertsup real,
	 cargasuportmaxima real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT tra_passagem_elevada_viaduto_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_passagem_elevada_viaduto_p_geom ON edgv.tra_passagem_elevada_viaduto_p USING gist (geom);

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p OWNER TO postgres;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_posicaopista_check 
	 CHECK (posicaopista = ANY(ARRAY[0 :: SMALLINT, 4 :: SMALLINT, 7 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 97 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_p_tipopassagviad_fk FOREIGN KEY (tipopassagviad)
	 REFERENCES dominios.tipo_passag_viad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_p ALTER COLUMN tipopassagviad SET DEFAULT 9999;

CREATE TABLE edgv.tra_passagem_elevada_viaduto_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 matconstr smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 necessitamanutencao smallint NOT NULL,
	 nrpistas integer,
	 nrfaixas integer,
	 posicaopista smallint NOT NULL,
	 largura real,
	 extensao real,
	 tipopavimentacao smallint NOT NULL,
	 tipopassagviad smallint NOT NULL,
	 vaolivrehoriz real,
	 vaovertical real,
	 gabhorizsup real,
	 gabvertsup real,
	 cargasuportmaxima real,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT tra_passagem_elevada_viaduto_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_passagem_elevada_viaduto_a_geom ON edgv.tra_passagem_elevada_viaduto_a USING gist (geom);

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a OWNER TO postgres;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_modaluso_check 
	 CHECK (modaluso = ANY(ARRAY[4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 9 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_matconstr_fk FOREIGN KEY (matconstr)
	 REFERENCES dominios.mat_constr (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a ALTER COLUMN matconstr SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_necessitamanutencao_fk FOREIGN KEY (necessitamanutencao)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a ALTER COLUMN necessitamanutencao SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_posicaopista_fk FOREIGN KEY (posicaopista)
	 REFERENCES dominios.situacao_espacial (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_posicaopista_check 
	 CHECK (posicaopista = ANY(ARRAY[0 :: SMALLINT, 4 :: SMALLINT, 7 :: SMALLINT, 12 :: SMALLINT, 13 :: SMALLINT, 97 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a ALTER COLUMN posicaopista SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_tipopavimentacao_fk FOREIGN KEY (tipopavimentacao)
	 REFERENCES dominios.tipo_pavimentacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a ALTER COLUMN tipopavimentacao SET DEFAULT 9999;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a
	 ADD CONSTRAINT tra_passagem_elevada_viaduto_a_tipopassagviad_fk FOREIGN KEY (tipopassagviad)
	 REFERENCES dominios.tipo_passag_viad (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_passagem_elevada_viaduto_a ALTER COLUMN tipopassagviad SET DEFAULT 9999;

CREATE TABLE edgv.tra_patio_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 modaluso smallint NOT NULL,
	 administracao smallint NOT NULL,
	 operacional smallint NOT NULL,
	 situacaofisica smallint NOT NULL,
	 finalidadepatio smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT tra_patio_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX tra_patio_a_geom ON edgv.tra_patio_a USING gist (geom);

ALTER TABLE edgv.tra_patio_a OWNER TO postgres;

ALTER TABLE edgv.tra_patio_a
	 ADD CONSTRAINT tra_patio_a_modaluso_fk FOREIGN KEY (modaluso)
	 REFERENCES dominios.modal_uso (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_patio_a ALTER COLUMN modaluso SET DEFAULT 9999;

ALTER TABLE edgv.tra_patio_a
	 ADD CONSTRAINT tra_patio_a_administracao_fk FOREIGN KEY (administracao)
	 REFERENCES dominios.administracao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_patio_a ALTER COLUMN administracao SET DEFAULT 9999;

ALTER TABLE edgv.tra_patio_a
	 ADD CONSTRAINT tra_patio_a_operacional_fk FOREIGN KEY (operacional)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_patio_a ALTER COLUMN operacional SET DEFAULT 9999;

ALTER TABLE edgv.tra_patio_a
	 ADD CONSTRAINT tra_patio_a_situacaofisica_fk FOREIGN KEY (situacaofisica)
	 REFERENCES dominios.situacao_fisica (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_patio_a ALTER COLUMN situacaofisica SET DEFAULT 9999;

ALTER TABLE edgv.tra_patio_a
	 ADD CONSTRAINT tra_patio_a_finalidadepatio_fk FOREIGN KEY (finalidadepatio)
	 REFERENCES dominios.finalidade_patio (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.tra_patio_a
	 ADD CONSTRAINT tra_patio_a_finalidadepatio_check 
	 CHECK (finalidadepatio = ANY(ARRAY[0 :: SMALLINT, 2 :: SMALLINT, 4 :: SMALLINT, 5 :: SMALLINT, 6 :: SMALLINT, 7 :: SMALLINT, 8 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.tra_patio_a ALTER COLUMN finalidadepatio SET DEFAULT 9999;

CREATE TABLE edgv.veg_floresta_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 especiepredominante smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_floresta_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_floresta_a_geom ON edgv.veg_floresta_a USING gist (geom);

ALTER TABLE edgv.veg_floresta_a OWNER TO postgres;

ALTER TABLE edgv.veg_floresta_a
	 ADD CONSTRAINT veg_floresta_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_floresta_a
	 ADD CONSTRAINT veg_floresta_a_classificacaoporte_check 
	 CHECK (classificacaoporte = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.veg_floresta_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_floresta_a
	 ADD CONSTRAINT veg_floresta_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_floresta_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_floresta_a
	 ADD CONSTRAINT veg_floresta_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_floresta_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_floresta_a
	 ADD CONSTRAINT veg_floresta_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_floresta_a ALTER COLUMN secundaria SET DEFAULT 9999;

ALTER TABLE edgv.veg_floresta_a
	 ADD CONSTRAINT veg_floresta_a_especiepredominante_fk FOREIGN KEY (especiepredominante)
	 REFERENCES dominios.especie (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_floresta_a ALTER COLUMN especiepredominante SET DEFAULT 9999;

CREATE TABLE edgv.veg_campinarana_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_campinarana_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_campinarana_a_geom ON edgv.veg_campinarana_a USING gist (geom);

ALTER TABLE edgv.veg_campinarana_a OWNER TO postgres;

ALTER TABLE edgv.veg_campinarana_a
	 ADD CONSTRAINT veg_campinarana_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campinarana_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_campinarana_a
	 ADD CONSTRAINT veg_campinarana_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campinarana_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_campinarana_a
	 ADD CONSTRAINT veg_campinarana_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campinarana_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_campinarana_a
	 ADD CONSTRAINT veg_campinarana_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campinarana_a ALTER COLUMN secundaria SET DEFAULT 9999;

CREATE TABLE edgv.veg_veg_cultivada_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 tipolavoura smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 terreno smallint NOT NULL,
	 cultivopredominante smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_veg_cultivada_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_veg_cultivada_a_geom ON edgv.veg_veg_cultivada_a USING gist (geom);

ALTER TABLE edgv.veg_veg_cultivada_a OWNER TO postgres;

ALTER TABLE edgv.veg_veg_cultivada_a
	 ADD CONSTRAINT veg_veg_cultivada_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_cultivada_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_cultivada_a
	 ADD CONSTRAINT veg_veg_cultivada_a_tipolavoura_fk FOREIGN KEY (tipolavoura)
	 REFERENCES dominios.tipo_lavoura (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_cultivada_a ALTER COLUMN tipolavoura SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_cultivada_a
	 ADD CONSTRAINT veg_veg_cultivada_a_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_cultura (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_cultivada_a ALTER COLUMN finalidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_cultivada_a
	 ADD CONSTRAINT veg_veg_cultivada_a_terreno_fk FOREIGN KEY (terreno)
	 REFERENCES dominios.condicao_terreno (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_cultivada_a ALTER COLUMN terreno SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_cultivada_a
	 ADD CONSTRAINT veg_veg_cultivada_a_cultivopredominante_fk FOREIGN KEY (cultivopredominante)
	 REFERENCES dominios.cultivo_predominante (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_cultivada_a ALTER COLUMN cultivopredominante SET DEFAULT 9999;

CREATE TABLE edgv.veg_veg_restinga_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_veg_restinga_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_veg_restinga_a_geom ON edgv.veg_veg_restinga_a USING gist (geom);

ALTER TABLE edgv.veg_veg_restinga_a OWNER TO postgres;

ALTER TABLE edgv.veg_veg_restinga_a
	 ADD CONSTRAINT veg_veg_restinga_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_restinga_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_restinga_a
	 ADD CONSTRAINT veg_veg_restinga_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_restinga_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_restinga_a
	 ADD CONSTRAINT veg_veg_restinga_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_restinga_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_restinga_a
	 ADD CONSTRAINT veg_veg_restinga_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_restinga_a ALTER COLUMN secundaria SET DEFAULT 9999;

CREATE TABLE edgv.veg_cerrado_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 vereda smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_cerrado_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_cerrado_a_geom ON edgv.veg_cerrado_a USING gist (geom);

ALTER TABLE edgv.veg_cerrado_a OWNER TO postgres;

ALTER TABLE edgv.veg_cerrado_a
	 ADD CONSTRAINT veg_cerrado_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_cerrado_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_cerrado_a
	 ADD CONSTRAINT veg_cerrado_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_cerrado_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_cerrado_a
	 ADD CONSTRAINT veg_cerrado_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_cerrado_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_cerrado_a
	 ADD CONSTRAINT veg_cerrado_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_cerrado_a ALTER COLUMN secundaria SET DEFAULT 9999;

ALTER TABLE edgv.veg_cerrado_a
	 ADD CONSTRAINT veg_cerrado_a_vereda_fk FOREIGN KEY (vereda)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_cerrado_a ALTER COLUMN vereda SET DEFAULT 9999;

CREATE TABLE edgv.veg_brejo_pantano_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_brejo_pantano_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_brejo_pantano_a_geom ON edgv.veg_brejo_pantano_a USING gist (geom);

ALTER TABLE edgv.veg_brejo_pantano_a OWNER TO postgres;

ALTER TABLE edgv.veg_brejo_pantano_a
	 ADD CONSTRAINT veg_brejo_pantano_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_brejo_pantano_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_brejo_pantano_a
	 ADD CONSTRAINT veg_brejo_pantano_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_brejo_pantano_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_brejo_pantano_a
	 ADD CONSTRAINT veg_brejo_pantano_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_brejo_pantano_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_brejo_pantano_a
	 ADD CONSTRAINT veg_brejo_pantano_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_brejo_pantano_a ALTER COLUMN secundaria SET DEFAULT 9999;

CREATE TABLE edgv.veg_mangue_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 tipomanguezal smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_mangue_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_mangue_a_geom ON edgv.veg_mangue_a USING gist (geom);

ALTER TABLE edgv.veg_mangue_a OWNER TO postgres;

ALTER TABLE edgv.veg_mangue_a
	 ADD CONSTRAINT veg_mangue_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_mangue_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_mangue_a
	 ADD CONSTRAINT veg_mangue_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_mangue_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_mangue_a
	 ADD CONSTRAINT veg_mangue_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_mangue_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_mangue_a
	 ADD CONSTRAINT veg_mangue_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_mangue_a ALTER COLUMN secundaria SET DEFAULT 9999;

ALTER TABLE edgv.veg_mangue_a
	 ADD CONSTRAINT veg_mangue_a_tipomanguezal_fk FOREIGN KEY (tipomanguezal)
	 REFERENCES dominios.tipo_manguezal (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_mangue_a ALTER COLUMN tipomanguezal SET DEFAULT 9999;

CREATE TABLE edgv.veg_reflorestamento_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 tipolavoura smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 terreno smallint NOT NULL,
	 cultivopredominante smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_reflorestamento_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_reflorestamento_a_geom ON edgv.veg_reflorestamento_a USING gist (geom);

ALTER TABLE edgv.veg_reflorestamento_a OWNER TO postgres;

ALTER TABLE edgv.veg_reflorestamento_a
	 ADD CONSTRAINT veg_reflorestamento_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_reflorestamento_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_reflorestamento_a
	 ADD CONSTRAINT veg_reflorestamento_a_tipolavoura_fk FOREIGN KEY (tipolavoura)
	 REFERENCES dominios.tipo_lavoura (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_reflorestamento_a
	 ADD CONSTRAINT veg_reflorestamento_a_tipolavoura_check 
	 CHECK (tipolavoura = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.veg_reflorestamento_a ALTER COLUMN tipolavoura SET DEFAULT 9999;

ALTER TABLE edgv.veg_reflorestamento_a
	 ADD CONSTRAINT veg_reflorestamento_a_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_cultura (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_reflorestamento_a ALTER COLUMN finalidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_reflorestamento_a
	 ADD CONSTRAINT veg_reflorestamento_a_terreno_fk FOREIGN KEY (terreno)
	 REFERENCES dominios.condicao_terreno (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_reflorestamento_a ALTER COLUMN terreno SET DEFAULT 9999;

ALTER TABLE edgv.veg_reflorestamento_a
	 ADD CONSTRAINT veg_reflorestamento_a_cultivopredominante_fk FOREIGN KEY (cultivopredominante)
	 REFERENCES dominios.cultivo_predominante (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_reflorestamento_a
	 ADD CONSTRAINT veg_reflorestamento_a_cultivopredominante_check 
	 CHECK (cultivopredominante = ANY(ARRAY[20 :: SMALLINT, 21 :: SMALLINT, 23 :: SMALLINT, 96 :: SMALLINT, 98 :: SMALLINT, 99 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.veg_reflorestamento_a ALTER COLUMN cultivopredominante SET DEFAULT 9999;

CREATE TABLE edgv.veg_campo_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 tipocampo smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_campo_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_campo_a_geom ON edgv.veg_campo_a USING gist (geom);

ALTER TABLE edgv.veg_campo_a OWNER TO postgres;

ALTER TABLE edgv.veg_campo_a
	 ADD CONSTRAINT veg_campo_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campo_a
	 ADD CONSTRAINT veg_campo_a_classificacaoporte_check 
	 CHECK (classificacaoporte = ANY(ARRAY[0 :: SMALLINT, 2 :: SMALLINT, 3 :: SMALLINT, 4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.veg_campo_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_campo_a
	 ADD CONSTRAINT veg_campo_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campo_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_campo_a
	 ADD CONSTRAINT veg_campo_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campo_a
	 ADD CONSTRAINT veg_campo_a_densidade_check 
	 CHECK (densidade = ANY(ARRAY[2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.veg_campo_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_campo_a
	 ADD CONSTRAINT veg_campo_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campo_a ALTER COLUMN secundaria SET DEFAULT 9999;

ALTER TABLE edgv.veg_campo_a
	 ADD CONSTRAINT veg_campo_a_tipocampo_fk FOREIGN KEY (tipocampo)
	 REFERENCES dominios.tipo_campo (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_campo_a ALTER COLUMN tipocampo SET DEFAULT 9999;

CREATE TABLE edgv.veg_caatinga_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_caatinga_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_caatinga_a_geom ON edgv.veg_caatinga_a USING gist (geom);

ALTER TABLE edgv.veg_caatinga_a OWNER TO postgres;

ALTER TABLE edgv.veg_caatinga_a
	 ADD CONSTRAINT veg_caatinga_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_caatinga_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_caatinga_a
	 ADD CONSTRAINT veg_caatinga_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_caatinga_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_caatinga_a
	 ADD CONSTRAINT veg_caatinga_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_caatinga_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_caatinga_a
	 ADD CONSTRAINT veg_caatinga_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_caatinga_a ALTER COLUMN secundaria SET DEFAULT 9999;

CREATE TABLE edgv.veg_veg_area_contato_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 antropizada smallint NOT NULL,
	 densidade smallint NOT NULL,
	 secundaria smallint NOT NULL,
	 tipoveg smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT veg_veg_area_contato_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX veg_veg_area_contato_a_geom ON edgv.veg_veg_area_contato_a USING gist (geom);

ALTER TABLE edgv.veg_veg_area_contato_a OWNER TO postgres;

ALTER TABLE edgv.veg_veg_area_contato_a
	 ADD CONSTRAINT veg_veg_area_contato_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_area_contato_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_area_contato_a
	 ADD CONSTRAINT veg_veg_area_contato_a_antropizada_fk FOREIGN KEY (antropizada)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_area_contato_a ALTER COLUMN antropizada SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_area_contato_a
	 ADD CONSTRAINT veg_veg_area_contato_a_densidade_fk FOREIGN KEY (densidade)
	 REFERENCES dominios.densidade (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_area_contato_a ALTER COLUMN densidade SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_area_contato_a
	 ADD CONSTRAINT veg_veg_area_contato_a_secundaria_fk FOREIGN KEY (secundaria)
	 REFERENCES dominios.auxiliar (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_area_contato_a ALTER COLUMN secundaria SET DEFAULT 9999;

ALTER TABLE edgv.veg_veg_area_contato_a
	 ADD CONSTRAINT veg_veg_area_contato_a_tipoveg_fk FOREIGN KEY (tipoveg)
	 REFERENCES dominios.tipo_vegetacao (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.veg_veg_area_contato_a ALTER COLUMN tipoveg SET DEFAULT 9999;

CREATE TABLE edgv.ver_arvore_isolada_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 geometriaaproximada boolean NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT ver_arvore_isolada_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX ver_arvore_isolada_p_geom ON edgv.ver_arvore_isolada_p USING gist (geom);

ALTER TABLE edgv.ver_arvore_isolada_p OWNER TO postgres;

CREATE TABLE edgv.ver_jardim_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 geometriaaproximada boolean NOT NULL,
	 classificacaoporte smallint NOT NULL,
	 tipolavoura smallint NOT NULL,
	 finalidade smallint NOT NULL,
	 terreno smallint NOT NULL,
	 cultivopredominante smallint NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT ver_jardim_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX ver_jardim_a_geom ON edgv.ver_jardim_a USING gist (geom);

ALTER TABLE edgv.ver_jardim_a OWNER TO postgres;

ALTER TABLE edgv.ver_jardim_a
	 ADD CONSTRAINT ver_jardim_a_classificacaoporte_fk FOREIGN KEY (classificacaoporte)
	 REFERENCES dominios.classificacao_porte (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.ver_jardim_a ALTER COLUMN classificacaoporte SET DEFAULT 9999;

ALTER TABLE edgv.ver_jardim_a
	 ADD CONSTRAINT ver_jardim_a_tipolavoura_fk FOREIGN KEY (tipolavoura)
	 REFERENCES dominios.tipo_lavoura (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.ver_jardim_a
	 ADD CONSTRAINT ver_jardim_a_tipolavoura_check 
	 CHECK (tipolavoura = ANY(ARRAY[0 :: SMALLINT, 1 :: SMALLINT, 2 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.ver_jardim_a ALTER COLUMN tipolavoura SET DEFAULT 9999;

ALTER TABLE edgv.ver_jardim_a
	 ADD CONSTRAINT ver_jardim_a_finalidade_fk FOREIGN KEY (finalidade)
	 REFERENCES dominios.finalidade_cultura (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.ver_jardim_a
	 ADD CONSTRAINT ver_jardim_a_finalidade_check 
	 CHECK (finalidade = ANY(ARRAY[4 :: SMALLINT, 9999 :: SMALLINT])); 

ALTER TABLE edgv.ver_jardim_a ALTER COLUMN finalidade SET DEFAULT 9999;

ALTER TABLE edgv.ver_jardim_a
	 ADD CONSTRAINT ver_jardim_a_terreno_fk FOREIGN KEY (terreno)
	 REFERENCES dominios.condicao_terreno (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.ver_jardim_a ALTER COLUMN terreno SET DEFAULT 9999;

ALTER TABLE edgv.ver_jardim_a
	 ADD CONSTRAINT ver_jardim_a_cultivopredominante_fk FOREIGN KEY (cultivopredominante)
	 REFERENCES dominios.cultivo_predominante (code) MATCH FULL
	 ON UPDATE NO ACTION ON DELETE NO ACTION;

ALTER TABLE edgv.ver_jardim_a ALTER COLUMN cultivopredominante SET DEFAULT 9999;

CREATE TABLE edgv.aux_moldura_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 escala varchar(255),
	 inom varchar(255),
	 mi varchar(255),
	 nome varchar(255),
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT aux_moldura_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX aux_moldura_a_geom ON edgv.aux_moldura_a USING gist (geom);

ALTER TABLE edgv.aux_moldura_a OWNER TO postgres;

CREATE TABLE edgv.aux_revisao_a(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 descricao varchar(255),
	 subfase_id integer,
	 corrigido boolean NOT NULL,
	 justificativa varchar(255),
	 observacao VARCHAR(255),
	 geom geometry(MultiPolygon, 4674),
	 CONSTRAINT aux_revisao_a_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX aux_revisao_a_geom ON edgv.aux_revisao_a USING gist (geom);

ALTER TABLE edgv.aux_revisao_a OWNER TO postgres;

CREATE TABLE edgv.aux_revisao_l(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 descricao varchar(255),
	 subfase_id integer,
	 corrigido boolean NOT NULL,
	 justificativa varchar(255),
	 observacao VARCHAR(255),
	 geom geometry(MultiLinestring, 4674),
	 CONSTRAINT aux_revisao_l_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX aux_revisao_l_geom ON edgv.aux_revisao_l USING gist (geom);

ALTER TABLE edgv.aux_revisao_l OWNER TO postgres;

CREATE TABLE edgv.aux_revisao_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 descricao varchar(255),
	 subfase_id integer,
	 corrigido boolean NOT NULL,
	 justificativa varchar(255),
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT aux_revisao_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX aux_revisao_p_geom ON edgv.aux_revisao_p USING gist (geom);

ALTER TABLE edgv.aux_revisao_p OWNER TO postgres;

CREATE TABLE edgv.aux_obstaculo_vertical_p(
	 id uuid NOT NULL DEFAULT uuid_generate_v4(),
	 nome varchar(255),
	 altitude real NOT NULL,
	 altura real NOT NULL,
	 observacao VARCHAR(255),
	 geom geometry(MultiPoint, 4674),
	 CONSTRAINT aux_obstaculo_vertical_p_pk PRIMARY KEY (id)
	 WITH (FILLFACTOR = 80)
);
CREATE INDEX aux_obstaculo_vertical_p_geom ON edgv.aux_obstaculo_vertical_p USING gist (geom);

ALTER TABLE edgv.aux_obstaculo_vertical_p OWNER TO postgres;
