Skip to content

Contiene le query di postgresql per l'importazione dei dati censuari catastali e la loro gestione in QGIS

License

Notifications You must be signed in to change notification settings

ludovico85/gestione-dati-censuari-catasto-postgresql-qgis

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

54 Commits
 
 
 
 
 
 
 
 

Repository files navigation

gestione-dati-censuari-catasto-postgresql-qgis

Contiene le query di postgresql per l'importazione dei dati censuari catastali e la loro gestione in QGIS

GitHub last commit

Contenuti

  1. Prerequisiti
  2. Breve descrizione dei dati catastali censuari
  3. Importazione delle cartografie catastali in CXF (opzionale)
  4. Creazione del database e degli schemi in PostgreSQL
  5. Importazione dei dati in QGIS 5.1. catasto terreni 5.2. catasto fabbricati
  6. Elaborazione dei dati nello schema catasto_ter
  7. Elaborazione dei dati nello schema catasto_fab
  8. Relazioni in QGIS
  9. Modelli QGIS

1. Prerequisiti

Software necessari:

Dati:

  • Cartografie catastali in formato vettoriale (ad esempio importati dal plugin cxf_in)
  • Campo testuale nel vettoriale catastale che contiene l'identificativo della particella/fabbricato nel formato "codicecomune_foglio_particella" (es. H308_0052_125)
  • Dati censuari catasto fabbricati
  • Dati censuari catasto terreni

Struttra finale del database:

   -- database
     |-- catasto_terreni (schema)
       |-- ter (tabella)
       |-- tit (tabella)
       |-- sog (tabella)
       |-- codici_diritto (tabella)
       |-- qualita (tabella)
       |-- ter1 (vista)
       |-- ter2 (vista)
       |-- ter3 (vista)
       |-- ter4 (vista)
       |-- ter1_colnames (vista)
       |-- ter4_colnames (vista)
       |-- tit_colnames (vista)
       |-- titg (vista)
       |-- titp (vista)
       |-- sogg (vista)
       |-- sogp (vista)
       |-- titg_sogg (vista)
       |-- titp_sogp (vista)
       |-- tit_sogp_sogg_partite_speciali (vista)
       |-- dati_censuari_ter
     |-- catasto_fabbricati (schema)
       |-- fab (tabella)
       |-- tit (tabella)
       |-- sog (tabella)
       |-- partite_speciali_fabbricati (tabella)
       |-- categoria_catastale (tabella)
       |-- toponimo (tabella)
       |-- fab1 (vista)
       |-- fab2 (vista)
       |-- fab3 (vista)
       |-- fab4 (vista)
       |-- fab5 (vista)
       |-- fab1_colnames (vista)
       |-- fab2_colnames (vista)
       |-- fab3_colnames (vista)
       |-- fab4_colnames (vista)
       |-- fab1_2_3_4_5 (vista)
       |-- tit_colnames (vista)
       |-- titg (vista)
       |-- titp (vista)
       |-- sogg (vista)
       |-- sogp (vista)
       |-- titg_sogg (vista)
       |-- titp_sogp (vista)
       |-- tit_sogp_sogg (vista)
       |-- dati_censuari_fab (vista)

2. Breve descrizione dei dati catastali censuari

Le informazioni descritte in questa sezione derivano dal documento a cura dell'Agenzia dell'Entrate (DOC. ES-23-IS-05) liberamente consultabile all'indirizzo: https://wwwt.agenziaentrate.gov.it/mt/ServiziComuniIstituzioni/ES-23-IS-05_100909.pdf.

Per maggiori dettagli sui servizi riservati ai comuni di può consultare: https://www.agenziaentrate.gov.it/portale/web/guest/schede/fabbricatiterreni/portale-per-i-comuni/servizi-portale-dei-comuni/estrazione-dati-catastali.

I dati censuari sono costituiti da 4 tipi di file:

  • file fabbricati (.FAB);
  • file terreni (.TER);
  • file soggetti (.SOG);
  • file titolarità (.TIT);
  • file parametri della richiesta (.PRM).

Ogni tipo di file è costituito da una tabella che può contenere diversi tipi di record. Il collegamento tra i tipi di file è assicurato dalla presenta di chiavi specifiche:

  • .FAB/.TER contengono la chiave identificativo immobile;
  • .SOG contiene la chiave identificativo soggetto;
  • .TIT contiene sia la chiave identificativo immobile che la chiave identificativo soggetto (oltre che la chiave identificativo titolarietà);

3. Importazione delle cartografie catastali in CXF (opzionale)

Utilizzare il plugin cfx_in per l'importazione delle cartografie catastali.

4. Creazione del database e degli schemi in PostgreSQL

  • Creare un nuovo database in PostgreSQL
  • Creare uno schema denominato catasto_terreni e uno schemda denominato catasto_fabbricati
CREATE SCHEMA IF NOT EXISTS catasto_terreni;
CREATE SCHEMA IF NOT EXISTS catasto_fabbricati;

5. Importazione dei dati in QGIS

5.1. Catasto terreni

Caricare in QGIS un nuovo layer testo delimitato e selezionare il file con estensione .TER. Importare con i seguenti parametri:

  • Formato file
    • Delimitatori personalizzati 🠊 Altri 🠊 |
    • Virgolette 🠊 vuoto
    • Caratteri di controllo 🠊 vuoto
  • Opzioni Record e campi
    • non spuntare "Il primo record ha i nomi dei campi"
    • spuntare "La virgola è il separatore decimale"
  • Definizione della geometria
    • Nessuna geometria

Nel nome del layer utilizzare 'ter'

ter

Assicurarsi di avere la connessione adl database creato nel punto 4

Dagli Strumenti di Processing di QGIS cercare Esporta in PostgreSQL. Inserire i seguenti parametri:

  • Layer da importare 🠊 ter
  • Database 🠊 il nome del database creato al punto 4
  • Schema 🠊 catasto_terreni
  • Nome della tabella 🠊 ter

Ripetere i passaggi precedenti per importare le tabelle .TIT e .SOG

Alla fine della procedura il database dovrebbe essere così organizzato:

   -- database
     |-- catasto_terreni
       |-- ter
       |-- tit
       |-- sog
     |-- catasto_fabbricati

5.2. Catasto fabbricati

Caricare in QGIS un nuovo layer testo delimitato e selezionare il file con estensione .FAB. Importare con i seguenti parametri:

  • Formato file
    • delimitatori personalizzati 🠊 Altri 🠊 |
  • Opzioni Record e campi
    • non spuntare "Il primo record ha i nomi dei campi"
    • spuntare "La virgola è il separatore decimale"
  • Definizione della geometria
    • Nessuna geometria

Nel nome del layer utilizzare 'fab'

Assicurarsi di avere la connessione adl database creato nel punto 4

Dagli Strumenti di Processing di QGIS cercare Esporta in PostgreSQL. Inserire i seguenti parametri:

  • Layer da importare 🠊 fab
  • Database 🠊 il nome del database creato al punto 4
  • Schema 🠊 catasto_fabbricati
  • Nome della tabella 🠊 fab

Ripetere i passaggi precedenti per importare le tabelle .TIT e .SOG

Alla fine della procedura il database dovrebbe essere così organizzato:

   -- database
     |-- catasto_terreni
       |-- ter
       |-- tit
       |-- sog
     |-- catasto_fabbricati
       |-- ter
       |-- tit
       |-- sog

6. Elaborazione dei dati nello schema catasto_ter

Le elaborazioni possono essere fatte in PostgreSQL tramite command line, con PgAdmin oppure direttamente in QGIS utilizzando lo strumento Esegui SQL PostgreSQL

Creazione delle tabelle ausiliari codici_diritto, qualita

SET search_path TO catasto_terreni;
CREATE TABLE partite_speciali_terreni (
  pk_id INTEGER PRIMARY KEY GENERATED BY DEFAULT AS IDENTITY,
  codice TEXT,
  descrizione TEXT
);

INSERT INTO partite_speciali_terreni (codice, descrizione) VALUES
  ('1', 'aree di enti urbani e promiscui'),
  ('2', 'accessori comuni ad enti rurali e ad enti rurali e urbani'),
  ('3', 'aree di fabbricati rurali, o urbani da accertare, divisi in subalterni'),
  ('4', 'acque esenti da estimo'),
  ('5', 'strade pubbliche'),
  ('0', 'particelle soppresse');
CREATE TABLE codici_diritto (
  pk_id INTEGER PRIMARY KEY GENERATED BY DEFAULT AS IDENTITY,
  codice TEXT,
  descrizione TEXT
);

INSERT INTO codici_diritto (codice, descrizione) VALUES
  ('10','Proprietà'),
  ('1s','Proprietà  superficiaria'),
  ('1t','Proprietà  per l''area'),
  ('20','Nuda proprietà'),
  ('2s','Nuda proprietà  superficiaria'),
  ('30','Abitazione'),
  ('3','Comproprietario'),
  ('3s','Abitazione su proprietà  superficiaria'),
  ('40','Diritto del concedente'),
  ('4','Comproprietario per'),
  ('50','Enfiteusi'),
  ('60','Superficie'),
  ('70','Uso'),
  ('7','Comproprietario del fabbricato'),
  ('7s','Uso proprietà  superficiaria'),
  ('7s','Uso proprietà  superficiaria'),
  ('80','Usufrutto'),
  ('8a','Usufrutto con diritto di accrescimento'),
  ('8e','Usufrutto su enfiteusi'),
  ('8s','Usufrutto su proprietà  superficiaria'),
  ('8','Comproprietario per l''area'),
  ('90','Servità'),
  ('100','Oneri'),
  ('12','Concedente in parte'),
  ('14','Livellario parziale per'),
  ('15','Usufruttuario parziale per'),
  ('20','Livellario'),
  ('21','Livellario per'),
  ('22','Livellario in parte'),
  ('25','Enfiteuta in parte'),
  ('26','Colono perpetuo'),
  ('27','Colono perpetuo per'),
  ('28','Colono perpetuo in parte'),
  ('30','Usufruttuario parziale'),
  ('33','Cousufruttuario generale'),
  ('36','Usufruttuario generale di livello'),
  ('37','Usufruttuario parziale di livello'),
  ('39','Usufruttuario parziale di enfiteusi'),
  ('40','Usufruttuario generale di colonia'),
  ('41','Usufruttuario parziale di colonia'),
  ('42','Usufruttuario generale di dominio diretto'),
  ('43','Usufruttuario parziale di dominio diretto'),
  ('50','Cousufruttuario per'),
  ('52','Usuario perpetuo'),
  ('53','Usuario a tempo determinato'),
  ('60','Cousufruttuario di livello'),
  ('61','Cousufruttuario generale di livello'),
  ('62','Usufruttuario di livello di'),
  ('64','Comproprietario per parte di'),
  ('70','Usufruttuario di colonia per'),
  ('71','Usufruttuario di dominio diretto per'),
  ('72','Cousufruttuario generale con diritto di'),
  ('16','Utilista della superficie'),
  ('17','Utilista della superficie per'),
  ('35','Beneficiario'),
  ('65','Beneficiario per'),
  ('54','Beneficiario di dominio diretto'),
  ('46','Possessore'),
  ('47','Possessore per'),
  ('48','Compossessore'),
  ('49','Compossessore per'),
  ('55','Contestatario'),
  ('56','Contestatario per'),
  ('57','Contestatario per usufrutto'),
  ('99','Presenza di titolo non codificato'),
  ('990','Presenza di titolo non codificato'),
  ('0','Assenza di titolo');
CREATE TABLE qualita (
  pk_id INTEGER PRIMARY KEY GENERATED BY DEFAULT AS IDENTITY,
  codice TEXT,
  descrizione TEXT
);

INSERT INTO qualita (codice, descrizione) VALUES
  ('1','seminativo'),
  ('2','semin irrig'),
  ('3','semin arbor'),
  ('4','sem arb irr'),
  ('5','sem irr arb'),
  ('6','sem pez fos'),
  ('7','sem arb p f'),
  ('8','prato'),
  ('9','prato irrig'),
  ('10','prato arbor'),
  ('11','prato ir ar'),
  ('12','prato marc'),
  ('13','prato mar ar'),
  ('14','marcita'),
  ('15','risaia'),
  ('16','risaia stab'),
  ('17','orto'),
  ('18','orto irrig'),
  ('19','orto arbor'),
  ('20','orto ar irr'),
  ('21','orto frutt'),
  ('22','orto pez fos'),
  ('23','orto fiori'),
  ('24','orto ir fi'),
  ('25','ort viv flo'),
  ('26','vivaio'),
  ('27','viv orn fl'),
  ('28','giardini'),
  ('29','vigneto'),
  ('30','vigneto arb'),
  ('31','vigneto irr'),
  ('32','vig uva tav'),
  ('33','vign frutt'),
  ('34','vign ulivet'),
  ('35','vign mandor'),
  ('36','uliveto'),
  ('37','uliv agrum'),
  ('38','uliv fichet'),
  ('39','ul fich man'),
  ('40','uliv frass'),
  ('41','uliv frutt'),
  ('42','uliv sommac'),
  ('43','uliv vignet'),
  ('44','uliv sugher'),
  ('45','uliv mandor'),
  ('46','ul man pist'),
  ('47','frutteto'),
  ('48','frutt irrig'),
  ('49','agrumeto'),
  ('50','agrum aranc'),
  ('51','agrum irrig'),
  ('52','agrum uliv'),
  ('53','alpe'),
  ('54','aranceto'),
  ('55','canneto'),
  ('56','cappereto'),
  ('57','carrubeto'),
  ('58','castagneto'),
  ('59','cast frutto'),
  ('60','cast frass'),
  ('61','chiusa'),
  ('62','eucalipteto'),
  ('63','ficheto'),
  ('64','fico india'),
  ('65','fico mandor'),
  ('66','frassineto'),
  ('67','gelseto'),
  ('68','limoneto'),
  ('69','mandorleto'),
  ('70','mandor fich'),
  ('71','mandor fico'),
  ('72','mandarineto'),
  ('73','noceto'),
  ('74','noccioleto'),
  ('75','nocc vignet'),
  ('76','palmeto'),
  ('77','pescheto'),
  ('78','pioppeto'),
  ('79','pistacch'),
  ('80','pometo'),
  ('81','querceto'),
  ('82','querc ghian'),
  ('83','roseto'),
  ('84','saliceto'),
  ('85','salceto'),
  ('86','sommaccheto'),
  ('87','sommac arb'),
  ('88','somm mandor'),
  ('89','sommac uliv'),
  ('90','sughereto'),
  ('91','pascolo'),
  ('92','pascolo arb'),
  ('93','pasc cespug'),
  ('94','pascolo bc'),
  ('95','pascolo bm'),
  ('96','pascolo ba'),
  ('97','bosco ceduo'),
  ('98','bosco misto'),
  ('99','bosco alto'),
  ('100','palud spart'),
  ('101','incolt prod'),
  ('102','orto irr ar'),
  ('103','nocciol irr'),
  ('104','sem car irr'),
  ('105','pereto'),
  ('106','sem irr prot'),
  ('107','bosco rap ac'),
  ('126','serra'),
  ('127','funghicoltur'),
  ('130','arativi'),
  ('131','seminativi'),
  ('132','prati'),
  ('133','orti'),
  ('134','vigneti'),
  ('135','pascoli'),
  ('136','alpi'),
  ('137','lag pal st'),
  ('138','boschi'),
  ('150','incolt ster'),
  ('151','lago pubbl'),
  ('152','laguna'),
  ('153','stagno'),
  ('180','cava'),
  ('181','lago pesca'),
  ('182','miniera'),
  ('183','salina'),
  ('184','stagn pesca'),
  ('185','tonnara'),
  ('186','torbiera'),
  ('187','valle pesca'),
  ('188','acque priv'),
  ('200','aeroporto d'),
  ('201','aer fort d'),
  ('202','autovia sp'),
  ('203','area dem pp'),
  ('204','banchina'),
  ('205','cimitero'),
  ('206','ferrovia sp'),
  ('207','fortificaz'),
  ('208','giard pub'),
  ('209','giard dem'),
  ('210','giard com'),
  ('211','giard prov'),
  ('212','molo'),
  ('213','parco pubb'),
  ('214','parco deman'),
  ('215','parco comun'),
  ('216','parco prov'),
  ('217','p v rimembr'),
  ('218','pza d armi'),
  ('219','porto'),
  ('220','somm arg 2'),
  ('221','somm arg 3'),
  ('222','tranvia sp'),
  ('223','somm arg 1'),
  ('250','canale bon'),
  ('251','canale irr'),
  ('252','gora'),
  ('270','antichita'),
  ('271','area fab dm'),
  ('272','area promis'),
  ('273','area rurale'),
  ('274','area urbana'),
  ('275','corte urban'),
  ('276','costr no ab'),
  ('277','fa div sub'),
  ('278','fabb promis'),
  ('279','fabb rurale'),
  ('280','fabb diruto'),
  ('281','fr div sub'),
  ('282','ente urbano'),
  ('283','fu d accert'),
  ('284','porz acc fr'),
  ('285','porz acc fu'),
  ('286','porz di fa'),
  ('287','porz di fr'),
  ('288','porz rur fp'),
  ('290','porz di fu'),
  ('300','acque esent'),
  ('301','piazza pubb'),
  ('302','strade pubb'),
  ('350','accesso'),
  ('351','accessorio'),
  ('352','aia'),
  ('353','andito'),
  ('354','androne'),
  ('355','area'),
  ('356','ascensore'),
  ('357','autorimessa'),
  ('358','ballatoio'),
  ('359','bindolo'),
  ('360','bottino'),
  ('361','bucataio'),
  ('362','canale priv'),
  ('363','cantina'),
  ('364','capanna'),
  ('365','cappella'),
  ('366','carbonile'),
  ('367','casello'),
  ('368','casotto'),
  ('369','cisterna'),
  ('370','concimaia'),
  ('371','conigliera'),
  ('372','corridoio'),
  ('373','corte'),
  ('374','fontana'),
  ('375','fontanile'),
  ('376','forno'),
  ('377','frantoio'),
  ('378','garage'),
  ('379','garitta'),
  ('380','grotta'),
  ('381','ingresso'),
  ('382','latrina'),
  ('383','lavanderia'),
  ('384','lavatoio'),
  ('385','legnaia'),
  ('386','locale dep'),
  ('387','loggia'),
  ('388','luogo dep'),
  ('389','macero'),
  ('390','montacarichi'),
  ('391','muro'),
  ('392','noria'),
  ('393','oratorio'),
  ('394','palmeto'),
  ('395','passaggio'),
  ('396','passo'),
  ('397','piazza'),
  ('398','piazzale'),
  ('399','pollaio'),
  ('400','pompa'),
  ('401','porcile'),
  ('402','portico'),
  ('403','portineria'),
  ('404','portone'),
  ('405','pozzo'),
  ('406','resede'),
  ('407','rifugio ant'),
  ('408','rimessa'),
  ('409','ripostiglio'),
  ('410','scala'),
  ('411','scolo acqua'),
  ('412','seccatoio'),
  ('413','sedime'),
  ('414','sentina'),
  ('415','sorgiva'),
  ('416','sottoscala'),
  ('417','sottopassag'),
  ('418','spazio'),
  ('419','stalla'),
  ('420','strada priv'),
  ('421','terrazzo'),
  ('422','tettoia'),
  ('423','tinaia'),
  ('424','vano'),
  ('425','vasca'),
  ('450','rel ente ur'),
  ('451','rel acc com'),
  ('452','rel f d sub'),
  ('453','rel acq es'),
  ('454','relit strad'),
  ('455','terr n form'),
  ('500','casa e corte'),
  ('501','fabb e corte'),
  ('504','incolto'),
  ('505','improdutt'),
  ('506','sentiero'),
  ('507','ponte'),
  ('508','cavalcavia'),
  ('509','casa stalla'),
  ('510','chiesa'),
  ('511','edificabile'),
  ('512','cortile'),
  ('513','magazzino'),
  ('514','fosso'),
  ('515','casa'),
  ('516','edificio'),
  ('517','fabbricato'),
  ('602','lag pal sta'),
  ('993','modello 26'),
  ('997','sop var ter'),
  ('998','soppresso'),
  ('999','disponibile');

Creazione delle viste

Il file ter è costituito da 4 differenti tipi record (field_6). La particella è identificata attraverso il campo IDENTIFICATIVO IMMOBILE (field_3).

  • TIPO RECORD 1: contiene le caratteristiche della particella. E' il record di interesse che verrà utilizzato per ricostruire il dato spaziale;
  • TIPO RECORD 2: deduzioni della particella;
  • TIPO RECORD 3: riserva della particella;
  • TIPO RECORD 4: porzioni della particella.
CREATE OR REPLACE VIEW ter1 AS SELECT * from ter WHERE field_6 = '1';
CREATE OR REPLACE VIEW ter2 AS SELECT * from ter WHERE field_6 = '2';
CREATE OR REPLACE VIEW ter3 AS SELECT * from ter WHERE field_6 = '3';
CREATE OR REPLACE VIEW ter4 AS SELECT * from ter WHERE field_6 = '4';

Tipo di record 1

Dalla vista ter1 si selezionano alcuni campi d'interesse: i dati generali (da field_1 a field_6), gli elementi identificativi della particella (da field_7 a field_11), i dati caratteristici della particella (da field_12 a field_23) e il numero della partita (field_36).

CREATE OR REPLACE VIEW ter1_colnames AS SELECT
  t.field_1 AS codice_amministrativo,
  t.field_2 AS sezione,
  t.field_3 AS identificativo_immobile,
  t.field_4 AS tipo_immobile,
  t.field_5 AS progressivo,
  t.field_6 AS tipo_record,
  t.field_7 AS foglio,
  t.field_8 AS numero,
  t.field_9 AS denominatore,
  t.field_10 AS subalterno,
  t.field_11 AS edificialita,
  t.field_12 AS qualita,
  q.descrizione AS descrizione_qualita,
  t.field_13 AS classe,
  t.field_14 AS ettari,
  t.field_15 AS are,
  t.field_16 AS centiare,
  t.field_17 AS flag_reddito,
  t.field_18 AS flag_porzione,
  t.field_19 AS flag_deduzioni,
  t.field_20 AS reddito_dominicale_lire,
  t.field_21 AS reddito_agrario_lire,
  t.field_22 AS reddito_dominicale_euro,
  t.field_23 AS reddito_agrario_euro,
  REGEXP_REPLACE(t.field_36, '^0+', '') AS partita,
  p.descrizione AS descrizione_partita,
  CASE
    WHEN t.field_3 = ter4.field_3 THEN 'si' ELSE 'no'
  END AS porzioni
FROM ter1 t
LEFT JOIN qualita q ON t.field_12 = q.codice
LEFT JOIN partite_speciali_terreni p ON REGEXP_REPLACE(t.field_36, '^0+', '') = p.codice
LEFT JOIN ter4 ON ter4.field_3 = t.field_3;

Tipo di record 2

Le deuzioni non sono state elaborate.

Tipo di record 3

Oltre ai dati generali, contiene il codice della riserva e la partita di iscrizione riserva, quest'ultima già presente nel campo partita di ter1_colnames. Nessuna operazione necessaria.

Tipo di record 4

Non è possibile conoscere il numero di porzioni della particella a priori. Per tale motivo è stato scelto un massimo di 5 porzioni (che può essere modificato, cambiando la query).

CREATE OR REPLACE VIEW catasto_terreni.ter4_colnames AS SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_immobile,
  field_4 AS tipo_immobile,
  field_5 AS progressivo,
  field_6 AS tipo_record,
  field_7 AS identificativo_porzione_1, -- porzione AA
  field_8 AS qualita_1,
  a.descrizione AS descrizione_qualita_1,
  field_9 AS classe_1,
  field_10 AS ettari_1,
  field_11 AS are_1,
  field_12 AS centiare_1,
  field_13 AS identificativo_porzione_2, -- porzione AB
  field_14 AS qualita_2,
  b.descrizione AS descrizione_qualita_2,
  field_15 AS classe_2,
  field_16 AS ettari_2,
  field_17 AS are_2,
  field_18 AS centiare_2,
  field_19 AS identificativo_porzione_3, -- porzione AC
  field_20 AS qualita_3,
  c.descrizione AS descrizione_qualita_3,
  field_21 AS classe_3,
  field_22 AS ettari_3,
  field_23 AS are_3,
  field_24 AS centiare_3,
  field_25 AS identificativo_porzione_4, -- porzione AD
  field_26 AS qualita_4,
  d.descrizione AS descrizione_qualita_4,
  field_27 AS classe_4,
  field_28 AS ettari_4,
  field_29 AS are_4,
  field_30 AS centiare_4,
  field_31 AS identificativo_porzione_5, -- porzione AE
  field_32 AS qualita_5,
  d.descrizione AS descrizione_qualita_5,
  field_33 AS classe_5,
  field_34 AS ettari_5,
  field_35 AS are_5,
  field_36 AS centiare_5
FROM catasto_terreni.ter4 t
LEFT JOIN catasto_terreni.qualita a ON t.field_8 = a.codice
LEFT JOIN catasto_terreni.qualita b ON t.field_14 = b.codice
LEFT JOIN catasto_terreni.qualita c ON t.field_20 = c.codice
LEFT JOIN catasto_terreni.qualita d ON t.field_26 = d.codice
LEFT JOIN catasto_terreni.qualita e ON t.field_32 = e.codice;

Titolarità

Si costruisce dapprima la vista con il nome dei campi e qualche informazione aggiuntiva (come la descrizione del diritto), successivamente si suddivide il dataset per le titolarità delle persone fisiche e dei soggetti giuridici.

CREATE OR REPLACE VIEW tit_colnames AS SELECT DISTINCT ON (field_28)
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_soggetto,
  field_4 AS tipo_soggetto,
  field_5 AS identificativo_immobile,
  field_6 AS tipo_immobile,
  REGEXP_REPLACE(field_7, '\s', '', 'g') AS codici_diritto,
  field_8 AS titolo_non_codificato,
  field_9 AS quota_numeratore_possesso,
  field_10 AS quota_denominatore_possesso,
  field_11 AS regime,
  field_12 AS soggetto_riferimento,
  field_13 AS data_validita_atto_generato,
  field_14 AS tipo_nota_generato,
  field_15 AS numero_nota_generato,
  field_16 AS progressivo_nota_generato,
  field_17 AS anno_nota_generato,
  field_18 AS data_registrazione_atti_generato,
  field_19 AS partita,
  field_20 AS data_validita_atto_concluso,
  field_21 AS tipo_nota_concluso,
  field_22 AS numero_nota_concluso,
  field_23 AS progessivo_nota_concluso,
  field_24 AS anno_nota_concluso,
  field_25 AS data_registrazione_atti_concluso,
  field_26 AS identificativo_mutazione_iniziale,
  field_27 AS identificativo_mutazione_finale,
  field_28 AS identificativo_titolarita,
  field_29 AS codice_causale_atto_generante,
  field_30 AS descrizione_atto_generante,
  d.descrizione AS descrizione_diritto
FROM tit
LEFT JOIN catasto_terreni.codici_diritto d ON REGEXP_REPLACE(tit.field_7, '\s', '', 'g') = d.codice
CREATE OR REPLACE VIEW titp AS
SELECT *
FROM tit_colnames
WHERE tipo_soggetto = 'P';
CREATE OR REPLACE VIEW titg AS
SELECT *
FROM tit_colnames
WHERE tipo_soggetto = 'G';

Soggetti

Si ricostiuiscono dapprima i nomi dei campi per le perosne fisiche e i soggetti giuridici.

CREATE OR REPLACE VIEW sogp AS
SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_soggetto,
  field_4 AS tipo_soggetto,
  field_5 AS cognome,
  field_6 AS nome,
  field_7 AS sesso,
  field_8 AS data_nascita,
  field_9 AS codice_amministratvio_comune_nascita,
  field_10 AS codice_fiscale,
  field_11 AS indicazioni_supplementari
FROM sog
WHERE field_4 = 'P';
CREATE OR REPLACE VIEW sogg AS
SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_soggetto,
  field_4 AS tipo_soggetto,
  field_5 AS denominazione,
  field_6 AS codice_amministrativo_sede,
  field_7 AS codice_fiscale
FROM sog
WHERE field_4 = 'G';

Join titolarità soggetti

Si ricostituiscono le relazioni tra le titolarità e i soggetti (giuridici e persone fisiche) e successivamente si esegue l'union tra le due viste in modo da avere un un'unica vista con tutte le relazioni.

CREATE OR REPLACE VIEW titp_sogp AS
SELECT
  t.identificativo_immobile,
  t.tipo_immobile,
  t.identificativo_soggetto AS identificativo_soggetto_tit,
  t.identificativo_titolarita,
  t.descrizione_diritto AS diritto,
  CONCAT(t.quota_numeratore_possesso, '/', t.quota_denominatore_possesso) AS quota,
  p.identificativo_soggetto AS identificativo_soggetto_sogp,
  p.cognome,
  p.nome,
  p.data_nascita,
  p.codice_fiscale
FROM titp t
LEFT JOIN sogp p ON t.identificativo_soggetto = p.identificativo_soggetto;
CREATE OR REPLACE VIEW titg_sogg AS
SELECT
  t.identificativo_immobile,
  t.tipo_immobile,
  t.identificativo_soggetto identificativo_soggetto_tit,
  t.identificativo_titolarita,
  t.descrizione_diritto AS diritto,
  CONCAT(t.quota_numeratore_possesso, '/', t.quota_denominatore_possesso) AS quota,
  g.identificativo_soggetto AS identificativo_soggetto_sogg,
  g.denominazione,
  g.codice_amministrativo_sede,
  g.codice_fiscale
FROM titg t
LEFT JOIN sogg g ON t.identificativo_soggetto = g.identificativo_soggetto;
CREATE OR REPLACE VIEW tit_sogp_sogg_partite_speciali AS
SELECT
  g.identificativo_immobile AS identificativo_immobile,
  g.tipo_immobile AS tipo_immobile,
  'soggetto giuridico' AS tipo_soggetto,
  g.diritto AS diritto,
  g.quota AS quota,
  g.identificativo_soggetto_tit AS identificativo_soggetto_tit,
  g.identificativo_soggetto_sogg AS identificativo_soggetto,
  g.identificativo_titolarita AS identificativo_titolarita,
  g.denominazione AS denominazione,
  g.codice_amministrativo_sede AS codice_amministrativo_sede,
  NULL AS data_nascita,
  g.codice_fiscale AS codice_fiscale
FROM catasto_terreni.titg_sogg g
UNION ALL
SELECT
  p.identificativo_immobile AS identificativo_immobile,
  p.tipo_immobile AS tipo_immobile,
  'persona fisica' AS tipo_soggetto,
  p.diritto AS diritto,
  p.quota AS quota,
  p.identificativo_soggetto_tit AS identificativo_soggetto_tit,
  p.identificativo_soggetto_sogp AS identificativo_soggetto,
  p.identificativo_titolarita AS identificativo_titolarita,
  CONCAT(p.cognome, ' ', p.nome) AS denominazione,
  NULL AS codice_amministrativo_sede,
  p.data_nascita AS data_nascita,
  p.codice_fiscale AS codice_fiscale
FROM catasto_terreni.titp_sogp p
UNION ALL
SELECT
  t.identificativo_immobile AS identificativo_immobile,
  t.tipo_immobile AS tipo_immobile,
  'partita speciale' AS tipo_soggetto,
  NULL AS diritto,
  NULL AS quota,
  NULL AS identificativo_soggetto_tit,
  NULL AS identificativo_soggetto,
  NULL AS identificativo_titolarita,
  t.descrizione_partita AS denominazione,
  NULL AS codice_amministrativo_sede,
  NULL AS data_nascita,
  NULL AS codice_fiscale
FROM catasto_terreni.ter1_colnames AS t
WHERE partita IN ('0','1','2','3','4','5');

Join finale dei dati censuari del catasto terreni

Ultimo passaggio è quello di unire le viste finali:

  • ter1_colnames: contiene le informazioni sulla particella
  • tit_sogp_sogg_partite_speciali: contiene le informazioni sulle titolarità e sui soggetti
CREATE OR REPLACE VIEW dati_censuari_ter AS
SELECT
  row_number() OVER ()::integer AS gid,
  ter.codice_amministrativo,
  ter.sezione,
  ter.identificativo_immobile AS identificativo_immobile_ter,
  ter.tipo_immobile,
  ter.progressivo,
  ter.tipo_record,
  ter.foglio,
  ter.numero,
  ter.denominatore,
  ter.subalterno,
  ter.edificialita,
  ter.qualita,
  ter.descrizione_qualita,
  ter.classe,
  ter.ettari,
  ter.are,
  ter.centiare,
  ter.flag_reddito,
  ter.flag_porzione,
  ter.flag_deduzioni,
  ter.reddito_dominicale_lire,
  ter.reddito_agrario_lire,
  ter.reddito_dominicale_euro,
  ter.reddito_agrario_euro,
  ter.partita,
  ter.descrizione_partita,
  ter.porzioni,
  CASE
    WHEN LENGTH(ter.foglio) = 1 THEN CONCAT(ter.codice_amministrativo, '_000', ter.foglio, '_', REGEXP_REPLACE(ter.numero, '^0+', ''))
    WHEN LENGTH(ter.foglio) = 2 THEN CONCAT(ter.codice_amministrativo, '_00', ter.foglio, '_', REGEXP_REPLACE(ter.numero, '^0+', ''))
    WHEN LENGTH(ter.foglio) = 3 THEN CONCAT(ter.codice_amministrativo, '_0', ter.foglio, '_', REGEXP_REPLACE(ter.numero, '^0+', ''))
    WHEN LENGTH(ter.foglio) = 4 THEN CONCAT(ter.codice_amministrativo, '_', ter.foglio, '_', REGEXP_REPLACE(ter.numero, '^0+', ''))
  END AS com_fg_plla,
  t.identificativo_immobile AS identificativo_immobile_tit,
  t.tipo_soggetto,
  t.diritto,
  t.quota,
  t.identificativo_titolarita,
  t.identificativo_soggetto_tit,
  t.identificativo_soggetto,
  t.denominazione,
  t.codice_amministrativo_sede,
  t.data_nascita,
  t.codice_fiscale
FROM ter1_colnames AS ter
LEFT JOIN tit_sogp_sogg_partite_speciali t ON ter.identificativo_immobile = t.identificativo_immobile;

7. Elaborazione dei dati nello schema catasto_fab

Le elaborazioni possono essere fatte in PostgreSQL tramite command line, con PgAdmin oppure direttamente in QGIS utilizzando lo strumento Esegui SQL PostgreSQL

Creazione delle tabelle ausiliari partite_speciali_fabbricati, categoria_catastale, codice_toponimo, codici_diritto

SET search_path TO catasto_fabbricati;
CREATE TABLE partite_speciali_fabbricati (
	pk_id INTEGER PRIMARY KEY GENERATED BY DEFAULT AS IDENTITY,
	codice TEXT,
	descrizione TEXT
);

INSERT INTO partite_speciali_fabbricati (codice, descrizione) VALUES
  ('0', 'beni comuni censibili'),
  ('A', 'beni comuni non censibili'),
  ('R', 'fabbricati rurali'),
  ('C', 'unità immobiliari soppresse');

Creazione tabella categorie catastali

CREATE TABLE categoria_catastale (
  pk_id integer NOT NULL GENERATED BY DEFAULT AS IDENTITY,
  codice TEXT,
  descrizione TEXT
);

INSERT INTO categoria_catastale (codice, descrizione) VALUES
  ('A01','abitazioni di tipo signorile'),
  ('A02','abitazioni di tipo civile'),
  ('A03','abitazioni di tipo economico'),
  ('A04','abitazioni di tipo popolare'),
  ('A05','abitazioni di tipo ultrapopolare'),
  ('A06','abitazioni di tipo rurale'),
  ('A07','abitazioni in villini'),
  ('A08','abitazioni in ville'),
  ('A09','castelli, palazzi di eminenti pregi artistici e storici'),
  ('A10','uffici e studi privati'),
  ('A11','abitazioni ed alloggi tipici dei luoghi'),
  ('B01','collegi, convitti; educandati, ricoveri orfanatrofi, ospizi, conventi, seminari, caserme'),
  ('B02','case di cura ed ospedali senza fini di lucro'),
  ('B03','prigioni e riformatori'),
  ('B04','uffici pubblici'),
  ('B05','scuole e laboratori scientifici'),
  ('B06','biblioteche, pinacoteche, musei, gallerie, accademie, circoli ricreativi e culturali senza fine di lucro, che non hanno sede in edifici della categoria A/9'),
  ('B07','cappelle ed oratori non destinati all’esercizio pubblico dei culti'),
  ('B08','magazzini sotterranei per deposito derrate'),
  ('C01','negozi e botteghe'),
  ('C02','magazzini e locali di deposito; cantine e soffitte se non unite all`unità immobiliare abitativa'),
  ('C03','laboratori per arti e mestieri'),
  ('C04','fabbricati e locali per esercizi sportivi'),
  ('C05','stabilimenti balneari e di acque curative'),
  ('C06','stalle, scuderie, rimesse ed autorimesse'),
  ('C07','tettoie; posti auto su aree private; posti auto coperti'),
  ('D01','opifici'),
  ('D02','alberghi e pensioni'),
  ('D03','teatri, cinematografi, sale per concerti e spettacoli; arene, parchi giochi, zoo-safari'),
  ('D04','case di cura e ospedali'),
  ('D05','istituti di credito, cambio ed assicurazione'),
  ('D06','fabbricati, locali, aree attrezzate per esercizi sportivi'),
  ('D07','fabbricati costruiti o adattati per le speciali esigenze di un`attivita` industriale e non suscettibile di destinazione diversa senza radicali trasformazioni'),
  ('D08','fabbricati costruiti o adattati per le speciali esigenze di un`attivita` commerciale e non suscettibili di destinazione diversa senza radicali trasformazioni'),
  ('D09','edifici galleggianti o assicurati a punti fissi del suolo; ponti privati soggetti a pedaggio; aree attrezzate per l’appoggio di palloni aerostatici e dirigibili'),
  ('D10','fabbricati per funzioni produttive connesse alle attività agricole'),
  ('E01','stazioni per servizi di trasporto terrestri, marittimi ed aerei; stazioni per metropolitane; stazioni per ferrovie; impianti di risalita in genere'),
  ('E02','ponti comunali e provinciali soggetti a pedaggio'),
  ('E03','costruzioni e fabbricati per speciali esigenze pubbliche'),
  ('E04','recinti chiusi per mercati, fiere, posteggio bestiame e simili'),
  ('E05','fabbricati costituenti fortificazioni e loro dipendenze'),
  ('E06','fari, semafori torri per rendere pubblico l’uso dell’orologio comunale'),
  ('E07','fabbricati per l’esercizio pubblico dei culti'),
  ('E08','fabbricati e costruzioni nei cimiteri esclusi i colombari, i sepolcri e le tombe di famiglia'),
  ('E09','edifici a destinazione particolare non compresi nelle categorie precedenti del gruppo E'),
  ('F01','area urbana'),
  ('F02','unità collabenti'),
  ('F03','unità in corso di costruzione'),
  ('F04','unità in corso di definizione'),
  ('F05','lastrico solare');
Creazione tabella codice toponimo

il database non è completo, bisogna inserire altre codifiche

CREATE TABLE codice_toponimo (
  pk_id INTEGER PRIMARY KEY GENERATED BY DEFAULT AS IDENTITY,
  codice INTEGER,
  denominazione TEXT
);

INSERT INTO codice_toponimo (codice, denominazione) VALUES
  ('0', ''),
  ('24', 'Borgo'),
  ('26', 'Calata),
  ('50', 'Circonvallazione'),
  ('54', 'Contrada'),
  ('58', 'Corso'),
  ('77','Frazione'),
  ('86', 'Largo'),
  ('90', 'Località'),
  ('130', 'Piazza'),
  ('156', 'Rampa')
  ('132', 'Piazzale'),
  ('134', 'Piazzetta'),
  ('162', 'Rione'),
  ('172', 'Salita'),
  ('185', 'Località'),
  ('204', 'Sottoportico'),
  ('210', 'Strada'),
  ('218', 'Supportico'),
  ('224', 'Traversa'),
  ('229', 'Sopportico'),
  ('232', 'Vallone'),
  ('236', 'Via'),
  ('240', 'Viale'),
  ('244', 'Vico'),
  ('246', 'Vicoletto'),
  ('248', 'Vicolo'),
  ('250', 'Villaggio'),
  ('273', 'Piane'),
  ('347', 'Case sparse'),
  ('394', 'Larghetto'),
  ('477', 'Prato'),
  ('524', 'Scesa'),
  ('546', 'Strada Comunale'),
  ('566', 'Strada Provinciale'),
  ('571', 'Strada Statale'),
  ('579', 'Strada Vicinale'),
  ('640', 'Via Provinciale'),
  ('661', 'Vico Chiuso'),
  ('662', 'Vico Cieco'),
  ('704', 'Colle'),
  ('705', 'Zona'),
  ('843', 'Monte'),
  ('894', 'Strada Poderale');

#### Creazione tabella codici diritto
CREATE TABLE codici_diritto (
  pk_id INTEGER PRIMARY KEY GENERATED BY DEFAULT AS IDENTITY,
  codice TEXT,
  descrizione TEXT
);

INSERT INTO codici_diritto (codice, descrizione) VALUES
  ('10','Proprietà'),
  ('1s','Proprietà  superficiaria'),
  ('1t','Proprietà  per l''area'),
  ('20','Nuda proprietà'),
  ('2s','Nuda proprietà  superficiaria'),
  ('30','Abitazione'),
  ('3','Comproprietario'),
  ('3s','Abitazione su proprietà  superficiaria'),
  ('40','Diritto del concedente'),
  ('4','Comproprietario per'),
  ('50','Enfiteusi'),
  ('60','Superficie'),
  ('70','Uso'),
  ('7','Comproprietario del fabbricato'),
  ('7s','Uso proprietà  superficiaria'),
  ('7s','Uso proprietà  superficiaria'),
  ('80','Usufrutto'),
  ('8a','Usufrutto con diritto di accrescimento'),
  ('8e','Usufrutto su enfiteusi'),
  ('8s','Usufrutto su proprietà  superficiaria'),
  ('8','Comproprietario per l''area'),
  ('90','Servità'),
  ('100','Oneri'),
  ('12','Concedente in parte'),
  ('14','Livellario parziale per'),
  ('15','Usufruttuario parziale per'),
  ('20','Livellario'),
  ('21','Livellario per'),
  ('22','Livellario in parte'),
  ('25','Enfiteuta in parte'),
  ('26','Colono perpetuo'),
  ('27','Colono perpetuo per'),
  ('28','Colono perpetuo in parte'),
  ('30','Usufruttuario parziale'),
  ('33','Cousufruttuario generale'),
  ('36','Usufruttuario generale di livello'),
  ('37','Usufruttuario parziale di livello'),
  ('39','Usufruttuario parziale di enfiteusi'),
  ('40','Usufruttuario generale di colonia'),
  ('41','Usufruttuario parziale di colonia'),
  ('42','Usufruttuario generale di dominio diretto'),
  ('43','Usufruttuario parziale di dominio diretto'),
  ('50','Cousufruttuario per'),
  ('52','Usuario perpetuo'),
  ('53','Usuario a tempo determinato'),
  ('60','Cousufruttuario di livello'),
  ('61','Cousufruttuario generale di livello'),
  ('62','Usufruttuario di livello di'),
  ('64','Comproprietario per parte di'),
  ('70','Usufruttuario di colonia per'),
  ('71','Usufruttuario di dominio diretto per'),
  ('72','Cousufruttuario generale con diritto di'),
  ('16','Utilista della superficie'),
  ('17','Utilista della superficie per'),
  ('35','Beneficiario'),
  ('65','Beneficiario per'),
  ('54','Beneficiario di dominio diretto'),
  ('46','Possessore'),
  ('47','Possessore per'),
  ('48','Compossessore'),
  ('49','Compossessore per'),
  ('55','Contestatario'),
  ('56','Contestatario per'),
  ('57','Contestatario per usufrutto'),
  ('99','Presenza di titolo non codificato'),
  ('990','Presenza di titolo non codificato'),
  ('0','Assenza di titolo');

Creazione delle viste

Il file fab è costituito da 5 differenti tipi record (field_6). Il fabbricato è identificato attraverso il campo IDENTIFICATIVO IMMOBILE (field_3).

  • TIPO DI RECORD 1: contiene le informazioni descrittive dell'unità immobiliare
  • TIPO DI RECORD 2: contiene gli identificativi dell'unità immobiliare
  • TIPO DI RECORD 3: contiene gli indirizzi dell'unità immobiliare
  • TIPO DI RECORD 4: contiene le unità comuni dell'unità immobiliare
  • TIPO DI RECORD 5: contiene le riserve dell'unità immobiliare
CREATE OR REPLACE VIEW fab1 AS SELECT * from fab WHERE field_6 = '1';
CREATE OR REPLACE VIEW fab2 AS SELECT * from fab WHERE field_6 = '2';
CREATE OR REPLACE VIEW fab3 AS SELECT * from fab WHERE field_6 = '3';
CREATE OR REPLACE VIEW fab4 AS SELECT * from fab WHERE field_6 = '4';
CREATE OR REPLACE VIEW fab5 AS SELECT * from fab WHERE field_6 = '5';

Tipo di record 1

Dalla vista fab1 si selezionano alcuni campi d'interesse: i dati generali (da field_1 a field_6), i dati relativi al classamento dell'unità immobiliare (da field_7 a field_13), i dati relativi all'ubicazione dell'immobile nel fabbricato (da field_14 a field_22) e la partita (field_35).

gli elementi identificativi della particella (da field_7 a field_11), i dati caratteristici della particella (da field_12 a field_23) e il numero della partita (field_36).

CREATE OR REPLACE VIEW fab1_colnames AS
SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_immobile,
  field_4 AS tipo_immboile,
  field_5 AS progressivo,
  field_6 AS tipo_record,
  field_7 AS zona,
  field_8 AS categoria,
  c.descrizione AS descrizione_categoria,
  field_9 AS classe,
  field_10 AS consistenza,
  CASE
    WHEN field_8 LIKE 'A%' THEN 'vani'
    WHEN field_8 LIKE 'B%' THEN 'metri cubi'
    WHEN field_8 LIKE 'C%' THEN 'metri quadri'
  END AS unita_misura_consistenza,
  field_11 AS superficie,
  field_12 AS rendita_lire,
  field_13 AS rendita_euro,
  field_14 AS lotto,
  field_15 AS edificio,
  field_16 AS scala,
  field_17 AS interno_1,
  field_18 AS interno_2,
  CASE
    WHEN field_17 IS NOT NULL THEN concat ('Int. ', CONCAT_WS('-', NULLIF(trim(REGEXP_REPLACE(fab1.field_17, '^0+', '')), ''), NULLIF(trim(REGEXP_REPLACE(fab1.field_18, '^0+', '')), '')))
  END AS interno_concat,
  field_19 AS piano_1,
  field_20 AS piano_2,
  field_21 AS piano_3,
  field_22 AS piano_4,
  CASE
    WHEN field_19 IS NOT NULL THEN concat ('Piano ', CONCAT_WS('--', NULLIF(trim(REGEXP_REPLACE(fab1.field_19, '^0+', '')), ''), NULLIF(trim(REGEXP_REPLACE(fab1.field_20, '^0+', '')),''),  NULLIF(trim(REGEXP_REPLACE(fab1.field_21, '^0+', '')), ''), NULLIF(trim(REGEXP_REPLACE(fab1.field_22, '^0+', '')), '')))
  END AS piano_concat,
  field_35 AS partita
FROM fab1
LEFT JOIN categoria_catastale c ON fab1.field_8 = c.codice;

Tipo di record 2

Dalla vista fab2 si selezionano alcuni campi d'interesse: i dati generali (da field_1 a field_6), la tabella identificativi (da field_7 a field_12). Gli immobili graffati (campi aggiuntivi) sono stati solo codificati con si/no (presenza/assenza).

CREATE OR REPLACE VIEW fab2_colnames AS
SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_immobile,
  field_4 AS tipo_immboile,
  field_5 AS progressivo,
  field_6 AS tipo_record,
  field_7 AS sezione_urbana,
  field_8 AS foglio,
  field_9 AS numero,
  field_10 AS denominatore,
  field_11 AS subalterno,
  field_12 AS edificialita,
  CASE
    WHEN field_14 IS NOT NULL THEN 'si' ELSE 'no'
  END AS immobili_graffati
FROM fab2;

Tipo di record 3

Dalla vista fab3 si selezionano alcuni campi d'interesse: i dati generali (da field_1 a field_6), la tabella indirizzi (da field_7 a field_12). Dal momento in cui possono essere presenti più indirizzi (con altrettanti campi), e non avendo la possibilità di conoscere a priori se esistono più indirizzi, è stato scelto di considerarne un numero massimo di 4 (dato che si può variare modificando la query). L'indirizzo valido è sempre l'ultimo.

CREATE OR REPLACE VIEW fab3_colnames AS
SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_immobile,
  field_4 AS tipo_immboile,
  field_5 AS progressivo,
  field_6 AS tipo_record,
  field_7 AS toponimo,
  field_8 AS indirizzo,
  field_9 AS civico_1,
  field_10 AS civico_2,
  field_11 AS civico_3,
  field_12 AS codice_strada,
  field_13 AS toponimo_a,
  field_14 AS indirizzo_a,
  field_15 AS civico_1_a,
  field_16 AS civico_2_a,
  field_17 AS civico_3_a,
  field_18 AS codice_strada_a,
  field_19 AS toponimo_b,
  field_20 AS indirizzo_b,
  field_21 AS civico_1_b,
  field_22 AS civico_2_b,
  field_23 AS civico_3_b,
  field_24 AS codice_strada_b,
  field_25 AS toponimo_c,
  field_26 AS indirizzo_c,
  field_27 AS civico_1_c,
  field_28 AS civico_2_c,
  field_29 AS civico_3_c,
  field_30 AS codice_strada_c,
  CASE
    WHEN field_11 IS NULL AND field_10 IS NULL THEN CONCAT_WS (' ', NULLIF(trim(t.denominazione), ''), NULLIF(trim(field_8), ''), NULLIF(trim(REGEXP_REPLACE(field_9, '^0+', '')), ''))
    WHEN field_11 IS NULL AND field_10 IS NOT NULL THEN CONCAT_WS (' ', NULLIF(trim(t.denominazione), ''), NULLIF(trim(field_8), ''), NULLIF(trim(REGEXP_REPLACE(field_9, '^0+', '')), ''))
    WHEN field_11 IS NOT NULL AND field_10 IS NOT NULL THEN CONCAT_WS (' ', NULLIF(trim(t.denominazione), ''), NULLIF(trim(field_8), ''), NULLIF(trim(REGEXP_REPLACE(field_10, '^0+', '')), ''))
  END AS indirizzo_completo,
  CASE
    WHEN field_17 IS NULL AND field_16 IS NULL THEN CONCAT_WS (' ', NULLIF(trim(a.denominazione), ''), NULLIF(trim(field_14), ''), NULLIF(trim(REGEXP_REPLACE(field_15, '^0+', '')), ''))
    WHEN field_17 IS NULL AND field_16 IS NOT NULL THEN CONCAT_WS (' ', NULLIF(trim(a.denominazione), ''), NULLIF(trim(field_14), ''), NULLIF(trim(REGEXP_REPLACE(field_15, '^0+', '')), ''))
    WHEN field_17 IS NOT NULL AND field_16 IS NOT NULL THEN CONCAT_WS (' ', NULLIF(trim(a.denominazione), ''), NULLIF(trim(field_14), ''), NULLIF(trim(REGEXP_REPLACE(field_16, '^0+', '')),''))
  END AS indirizzo_completo_a,
  CASE
    WHEN field_23 IS NULL AND field_22 IS NULL THEN CONCAT_WS (' ', NULLIF(trim(b.denominazione), ''), NULLIF(trim(field_20), ''), NULLIF(trim(REGEXP_REPLACE(field_21, '^0+', '')),''))
    WHEN field_23 IS NULL AND field_22 IS NOT NULL THEN CONCAT_WS (' ', NULLIF(trim(b.denominazione), ''), NULLIF(trim(field_20), ''), NULLIF(trim(REGEXP_REPLACE(field_21, '^0+', '')),''))
    WHEN field_23 IS NOT NULL AND field_22 IS NOT NULL THEN CONCAT_WS (' ', NULLIF(trim(b.denominazione), ''), NULLIF(trim(field_20), ''), NULLIF(trim(REGEXP_REPLACE(field_22, '^0+', '')),''))
  END AS indirizzo_completo_b,
  CASE
    WHEN field_29 IS NULL AND field_28 IS NULL THEN CONCAT_WS (' ', NULLIF(trim(c.denominazione), ''), NULLIF(trim(field_26), ''), NULLIF(trim(REGEXP_REPLACE(field_27, '^0+', '')),''))
    WHEN field_29 IS NULL AND field_28 IS NOT NULL THEN CONCAT_WS (' ', NULLIF(trim(c.denominazione), ''), NULLIF(trim(field_26), ''), NULLIF(trim(REGEXP_REPLACE(field_27, '^0+', '')),''))
    WHEN field_29 IS NOT NULL AND field_28 IS NOT NULL THEN CONCAT_WS (' ', NULLIF(trim(c.denominazione), ''), NULLIF(trim(field_26), ''), NULLIF(trim(REGEXP_REPLACE(field_28, '^0+', '')),''))
  END AS indirizzo_completo_c
FROM fab3
LEFT JOIN codice_toponimo t ON CAST(fab3.field_7 AS INTEGER) = t.codice
LEFT JOIN codice_toponimo a ON CAST(fab3.field_13 AS INTEGER) = a.codice
LEFT JOIN codice_toponimo b ON CAST(fab3.field_19 AS INTEGER) = b.codice
LEFT JOIN codice_toponimo c ON CAST(fab3.field_25 AS INTEGER) = c.codice;

Tipo di record 4

Dalla vista fab4 si selezionano alcuni campi d'interesse: i dati generali (da field_1 a field_6), la tabella unità comuni (da field_7 a field_12).

CREATE OR REPLACE VIEW fab4_colnames AS
SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_immobile,
  field_4 AS tipo_immboile,
  field_5 AS progressivo,
  field_6 AS tipo_record,
  field_7 AS sezione_urbana,
  field_8 AS foglio,
  field_9 AS numero,
  field_10 AS denominatore,
  field_11 AS subalterno
FROM fab4;

fab1_2_3_4_5

CREATE OR REPLACE VIEW fab1_2_3_4_5 AS
SELECT
  fab1.codice_amministrativo,
  fab1.sezione,
  fab1.identificativo_immobile,
  fab1.progressivo,
  fab1.tipo_record,
  fab1.zona,
  fab1.categoria,
  fab1.descrizione_categoria,
  fab1.classe,
  fab1.consistenza,
  fab1.unita_misura_consistenza,
  fab1.superficie,
  fab1.rendita_lire,
  fab1.rendita_euro,
  fab1.lotto,
  fab1.edificio,
  fab1.scala,
  fab1.interno_1,
  fab1.interno_2,
  fab1.interno_concat,
  fab1.piano_1,
  fab1.piano_2,
  fab1.piano_3,
  fab1.piano_4,
  fab1.piano_concat,
  CONCAT_WS ('-', NULLIF(trim(fab1.partita), ''), NULLIF(trim(psf.descrizione), '')) AS partita,
  fab2.foglio,
  fab2.numero,
  fab2.denominatore,
  fab2.subalterno,
  fab2.edificialita,
  fab2.immobili_graffati,
  CASE
    WHEN fab3.indirizzo_completo IS NOT NULL AND fab3.indirizzo_completo_a = '' AND fab3.indirizzo_completo_b = '' AND fab3.indirizzo_completo_c = '' THEN indirizzo_completo
    WHEN fab3.indirizzo_completo_a IS NOT NULL AND fab3.indirizzo_completo_b = '' AND fab3.indirizzo_completo_c = '' THEN CONCAT (fab3.indirizzo_completo, ' - ', fab3.indirizzo_completo_a)
    WHEN fab3.indirizzo_completo_b IS NOT NULL AND fab3.indirizzo_completo_c = '' THEN CONCAT (fab3.indirizzo_completo, ' - ', fab3.indirizzo_completo_a, ' - ', fab3.indirizzo_completo_b)
    WHEN fab3.indirizzo_completo_c IS NOT NULL THEN CONCAT (fab3.indirizzo_completo, ' - ', fab3.indirizzo_completo_a, ' - ', fab3.indirizzo_completo_b, ' - ', fab3.indirizzo_completo_c)
  END AS indirizzo_completo,
  CASE
    WHEN fab4.identificativo_immobile = fab1.identificativo_immobile THEN 'utilità comuni dell''unità immobiliare'
  END AS utilita_comuni,
  CASE
    WHEN fab5.field_3 = fab1.identificativo_immobile THEN 'riserva dell''unità immobiliare'
  END AS riserva
FROM fab1_colnames fab1
LEFT JOIN fab2_colnames fab2 ON fab1.identificativo_immobile = fab2.identificativo_immobile
LEFT JOIN fab3_colnames fab3 ON fab1.identificativo_immobile = fab3.identificativo_immobile
LEFT JOIN fab4_colnames fab4 ON fab1.identificativo_immobile = fab4.identificativo_immobile
LEFT JOIN fab5 fab5 ON fab1.identificativo_immobile = fab5.field_3
LEFT JOIN partite_speciali_fabbricati psf ON fab1.partita = psf.codice;

Titolarità

Si costruisce dapprima la vista con il nome dei campi e qualche informazione aggiuntiva (come la descrizione del diritto), successivamente si suddivide il dataset per le titolarità delle persone fisiche e dei soggetti giuridici.

CREATE OR REPLACE VIEW tit_colnames AS
SELECT DISTINCT ON (field_28)
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_soggetto,
  field_4 AS tipo_soggetto,
  field_5 AS identificativo_immobile,
  field_6 AS tipo_immobile,
  REGEXP_REPLACE(field_7, '\s', '', 'g') AS codici_diritto,
  field_8 AS titolo_non_codificato,
  field_9 AS quota_numeratore_possesso,
  field_10 AS quota_denominatore_possesso,
  field_11 AS regime,
  field_12 AS soggetto_riferimento,
  field_13 AS data_validita_atto_generato,
  field_14 AS tipo_nota_generato,
  field_15 AS numero_nota_generato,
  field_16 AS progressivo_nota_generato,
  field_17 AS anno_nota_generato,
  field_18 AS data_registrazione_atti_generato,
  field_19 AS partita,
  field_20 AS data_validita_atto_concluso,
  field_21 AS tipo_nota_concluso,
  field_22 AS numero_nota_concluso,
  field_23 AS progessivo_nota_concluso,
  field_24 AS anno_nota_concluso,
  field_25 AS data_registrazione_atti_concluso,
  field_26 AS identificativo_mutazione_iniziale,
  field_27 AS identificativo_mutazione_finale,
  field_28 AS identificativo_titolarita,
  field_29 AS codice_causale_atto_generante,
  field_30 AS descrizione_atto_generante,
  d.descrizione AS descrizione_diritto
FROM tit
LEFT JOIN catasto_terreni.codici_diritto d ON REGEXP_REPLACE(tit.field_7, '\s', '', 'g') = d.codice;
CREATE OR REPLACE VIEW titp AS
SELECT *
FROM tit_colnames
WHERE tipo_soggetto = 'P';
CREATE OR REPLACE VIEW titg AS
SELECT *
FROM tit_colnames
WHERE tipo_soggetto = 'G';

Soggetti

Si ricostiuiscono dapprima i nomi dei campi per le persone fisiche e i soggetti giuridici.

CREATE OR REPLACE VIEW sogp AS
SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_soggetto,
  field_4 AS tipo_soggetto,
  field_5 AS cognome,
  field_6 AS nome,
  field_7 AS sesso,
  field_8 AS data_nascita,
  field_9 AS codice_amministratvio_comune_nascita,
  field_10 AS codice_fiscale,
  field_11 AS indicazioni_supplementari
FROM sog
WHERE field_4 = 'P';
CREATE OR REPLACE VIEW sogg AS
SELECT
  field_1 AS codice_amministrativo,
  field_2 AS sezione,
  field_3 AS identificativo_soggetto,
  field_4 AS tipo_soggetto,
  field_5 AS denominazione,
  field_6 AS codice_amministrativo_sede,
  field_7 AS codice_fiscale
FROM sog
WHERE field_4 = 'G';

Join titolarità soggetti

Si ricostituiscono le relazioni tra le titolarità e i soggetti (giuridici e persone fisiche) e successivamente si esegue l'union tra le due viste in modo da avere un un'unica vista con tutte le relazioni.

CREATE OR REPLACE VIEW titp_sogp AS
SELECT
  t.identificativo_immobile,
  t.tipo_immobile,
  t.identificativo_soggetto AS identificativo_soggetto_tit,
  t.identificativo_titolarita,
  t.descrizione_diritto AS diritto,
  concat(t.quota_numeratore_possesso, '/', t.quota_denominatore_possesso) AS quota,
  p.identificativo_soggetto AS identificativo_soggetto_sogp,
  p.cognome,
  p.nome,
  p.data_nascita,
  p.codice_fiscale
FROM titp t
LEFT JOIN sogp p ON t.identificativo_soggetto = p.identificativo_soggetto;
CREATE OR REPLACE VIEW titg_sogg AS
SELECT
  t.identificativo_immobile,
  t.tipo_immobile,
  t.identificativo_soggetto identificativo_soggetto_tit,
  t.identificativo_titolarita,
  t.descrizione_diritto AS diritto,
  concat(t.quota_numeratore_possesso, '/', t.quota_denominatore_possesso) AS quota,
  g.identificativo_soggetto AS identificativo_soggetto_sogg,
  g.denominazione,
  g.codice_amministrativo_sede,
  g.codice_fiscale
FROM titg t
LEFT JOIN sogg g ON t.identificativo_soggetto = g.identificativo_soggetto;
CREATE OR REPLACE VIEW tit_sogp_sogg AS
SELECT
  g.identificativo_immobile AS identificativo_immobile,
  g.tipo_immobile AS tipo_immobile,
  'soggetto giuridico' AS tipo_soggetto,
  g.diritto AS diritto,
  g.quota AS quota,
  g.identificativo_soggetto_tit AS identificativo_soggetto_tit,
  g.identificativo_soggetto_sogg AS identificativo_soggetto,
  g.denominazione AS denominazione,
  g.codice_amministrativo_sede AS codice_amministrativo_sede,
  NULL AS data_nascita,
  g.codice_fiscale AS codice_fiscale
  FROM catasto_fabbricati.titg_sogg g
UNION ALL
SELECT
  p.identificativo_immobile AS identificativo_immobile,
  p.tipo_immobile AS tipo_immobile,
  'persona fisica' AS tipo_soggetto,
  p.diritto AS diritto,
  p.quota AS quota,
  p.identificativo_soggetto_tit AS identificativo_soggetto_tit,
  p.identificativo_soggetto_sogp AS identificativo_soggetto,
  concat(p.cognome, ' ', p.nome) AS denominazione,
  NULL AS codice_amministrativo_sede,
  p.data_nascita AS data_nascita,
  p.codice_fiscale AS codice_fiscale
FROM catasto_fabbricati.titp_sogp p;

Join finale dei dati censuari del catasto fabbricati

Ultimo passaggio è quello di unire le viste finali:

  • fab1_2_3_4_5: contiene le informazioni sui fabbricati
  • tit_sogp_sogg: contiene le informazioni sulle titolarità e sui soggetti
CREATE OR REPLACE VIEW dati_censuari_fab AS
SELECT row_number() OVER ()::integer AS gid,
  fab.codice_amministrativo,
  fab.sezione,
  fab.identificativo_immobile AS identificativo_immobile_fab,
  fab.progressivo,
  fab.tipo_record,
  fab.zona,
  fab.categoria,
  fab.descrizione_categoria,
  fab.classe,
  fab.consistenza,
  fab.unita_misura_consistenza,
  fab.superficie,
  fab.rendita_lire,
  fab.rendita_euro,
  fab.lotto,
  fab.edificio,
  fab.scala,
  fab.interno_1,
  fab.interno_2,
  fab.piano_1,
  fab.piano_2,
  fab.piano_3,
  fab.piano_4,
  fab.partita,
  fab.foglio,
  fab.numero,
  fab.denominatore,
  fab.subalterno,
  fab.edificialita,
  fab.immobili_graffati,
  fab.indirizzo_completo AS indirizzo,
  CONCAT_WS (' ', NULLIF(trim(fab.indirizzo_completo), ''), NULLIF(trim(fab.piano_concat), ''), NULLIF(trim(fab.interno_concat), '') ) AS indirizzo_completo,
  fab.utilita_comuni,
  fab.riserva,
  CASE
    WHEN LENGTH(fab.foglio) = 1 THEN CONCAT(fab.codice_amministrativo, '_000', fab.foglio, '_', REGEXP_REPLACE(fab.numero, '^0+', ''))
    WHEN LENGTH(fab.foglio) = 2 THEN CONCAT(fab.codice_amministrativo, '_00', fab.foglio, '_', REGEXP_REPLACE(fab.numero, '^0+', ''))
    WHEN LENGTH(fab.foglio) = 3 THEN CONCAT(fab.codice_amministrativo, '_0', fab.foglio, '_', REGEXP_REPLACE(fab.numero, '^0+', ''))
    WHEN LENGTH(fab.foglio) = 4 THEN CONCAT(fab.codice_amministrativo, '_', fab.foglio, '_', REGEXP_REPLACE(fab.numero, '^0+', ''))
  END AS com_fg_plla,
  t.*
FROM fab1_2_3_4_5 AS fab
RIGHT JOIN tit_sogp_sogg t ON fab.identificativo_immobile = t.identificativo_immobile;

8. Relazioni in QGIS

In QGIS caricare il vettoriale del catasto terreni e/o fabbricati. Creare un campo com_fg_plla, con il calcolatore dei campi, identificativo della particella/fabbricato costiuito da: codicecomune_foglio_particella. Ad esempio se si hanno i campi codice_comune, foglio e mappale basta utilizzare l'espressione: CONCAT(codice_comune, '_',fg,'_', mappale). Il campo foglio deve avere 4 caratteri; Ad esempio il foglio 12 deve essere codificato come 0012. Per i fabbricati il mappale è di solito accompagnato dal simbolo + e quindi bisonga utilizzare l'espressione:CONCAT(codice_comune, '_',Foglio,'_', regexp_replace(mappale, '\\+', '')). N.B. Verficare sempre il nome dei campi Caricare la vista dati_censuari_ter (o dati_censuari_fab) dal database e creare la seguente relazione nelle proprietà di progetto di QGIS:

  • Nome: Elenco intestati
  • Layer padre: il vettoriale
  • Campo del Layer padre: com_fg_plla (Creato al punto precedente)
  • Layer figlio: dati_censuari_ter
  • Campo del Layer figlio: com_fg_plla

Interrogare la particella/fabbricato!

9. Modelli QGIS

Per automatizzare l'intero processo sono stati creati 2 modelli di QGIS (QGIS v. >3.16), uno per il catasto terreni e uno per il catasto fabbricati. Per utilizzare il modello occorre:

  • una connessione valida ad un database PostgreSQL
  • le tabelle .TER/.FAB, .SOG e .TIT caricate in QGIS come descritto al punto 5
  • le cartografie catastali come spiegato al punto 8

Download modelli

modelli

About

Contiene le query di postgresql per l'importazione dei dati censuari catastali e la loro gestione in QGIS

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages