source: trunk/info/info/alkisn/alkisfshist.php @ 417

Revision 417, 11.7 KB checked in by frank.jaeger, 5 years ago (diff)

Korrektur der Auskunft: Vorgängerflurstücke und Fortführungen bei Flurstücks-Historie.

RevLine 
[362]1<?php
2/*      Modul: alkisfshist.php
3
4        ALKIS-Buchauskunft, Kommunales Rechenzentrum Minden-Ravensberg/Lippe (Lemgo).
5        Flurstuecks-Historie fuer ein Flurstueckskennzeichen aus ALKIS PostNAS
6        Version:
7        2016-02-24 Version fuer norGIS-ALKIS-Import
[377]8        2016-11-29 HTML5, Gemeinsam genutzte Datenbanken ermöglichen (Filter Gemeinde)
[387]9        2017-06-06 Validierung Eingabeparameter, Feinkorrekturen
[389]10        2017-10-09 Sauber filtern auf NOT endet IS NULL
[391]11        2017-10-17 Deutsches Datumsformat fÃŒr Zeitpunkt der Entstehung
[400]12        2018-03-16 NULL-Werte in gemeinde und kreis in ax_historischesflurstueck berÃŒcksichtigen
[402]13        2018-04-23 &nodebug
[417]14        2018-11-19 Full-Schema: EntschlÃŒsseln "zeigtaufexternes_art" mit function fortfuehrungen(). Tab. "ax_historischesflurstueck" hat kein "vorgaengerflurstueckskennzeichen" mehr.
[362]15*/
16
17function fzerleg($fs) {
18/*      Flurstueckskennzeichen (20) zerlegen als lesbares Format (wie im Balken):
19        Dies FS-Kennz-Format wird auch als Eingabe in der Navigation akzeptiert
20   ....*....1....*....2
21   ll    fff     nnnn
22     gggg   zzzzz    __
23*/
24        $fst=rtrim($fs,"_");   
25        $zer=substr ($fst, 2, 4)."-".ltrim(substr($fst, 6, 3), "0")."-<b>".ltrim(substr($fst, 9, 5),"0");
26        $nenn=ltrim(substr($fst, 14), "0");
27        if ($nenn != "") {$zer.="/".$nenn;}
28        $zer.="</b>";
29        return $zer;
30}
31
32function vornach($dbarr) {
33// Datenbank-Array-Feld zeilenweise ausgeben als Selbst-Link
34        global $gkz, $showkey;
35        if ($dbarr == "") {
36                echo "(keine)";
37        } else {
38                $stri=trim($dbarr, "{}");
39                $arr = explode(",",$stri);
40                foreach($arr AS $val){
41                        echo "Flurst&uuml;ck <a title=' zur Flurst&uuml;ck Historie' href='".$_SERVER['PHP_SELF']."?gkz=".$gkz."&amp;fskennz=".$val;
42                        if ($showkey)   {echo "&amp;showkey=j";}
43                        echo "'>".fzerleg($val)."</a><br>";
44                }
45        }
46        return 0;
47}
48
49function gemkg_name($gkey) {
[377]50//      Schluessel wird ÃŒbergeben, Name dazu in der DB nachschlagen
[362]51        global $con;
[377]52        $sql ="SELECT bezeichnung FROM ax_gemarkung g WHERE g.gemarkungsnummer= $1 AND g.endet IS NULL LIMIT 1;";
[362]53        $v=array($gkey);
54        $res=pg_prepare("", $sql);
55        $res=pg_execute("", $v);
56        if (!$res) {echo "\n<p class='err'>Fehler bei Gemarkung.</p>";}
57        $zgmk=0;
[402]58        while($row = pg_fetch_assoc($res)) { // eigentlich nur EINE
[362]59                $gmkg=$row["bezeichnung"];
60                $zgmk++;
61        }
62        if ($zgmk == 0) {
63                echo "\n<p class='err'>Gemarkung ".$gkey." ist unbekannt.</p>";
64                return;
65        }
66        return $gmkg;
67}
68
69function such_vor_arr($fsk) {
[417]70// Suchen Vorgaenger zum aktuellen Flurst. Ausgabe von Selbst-Links Zeilenweise in <td>.
71// Akt. FS und hist.FS hat keine Verweise auf Vorgaenger. Darum in den Nachfolger-Verweisen von Hist.-FS suchen.
[377]72        global $gkz, $con, $debug, $showkey, $filtkreis, $filtgem;
[362]73
[400]74        $sqlv="SELECT 'h' AS ftyp, h.gml_id, h.flurstueckskennzeichen FROM ax_historischesflurstueck h "
75        ."WHERE $1 = ANY (h.nachfolgerflurstueckskennzeichen) AND h.endet IS NULL "
[389]76        ."UNION SELECT 'o' AS ftyp, o.gml_id, o.flurstueckskennzeichen FROM ax_historischesflurstueckohneraumbezug o "
[417]77        ."WHERE $1 = ANY (o.nachfolgerflurstueckskennzeichen) AND o.endet IS NULL ORDER BY flurstueckskennzeichen";
[362]78
79        $v=array($fsk);
80        $resv = pg_prepare("", $sqlv);
81        $resv = pg_execute("", $v);
82        if (!$resv) {
83                echo "\n<p class='err'>Fehler bei Vorg&auml;nger-FS.</p>";
[387]84                if ($debug > 2) {echo "\n<p class='dbg'>SQL=<br>".$sqlv."<br>$1='".$fsk."'</p>";}
[362]85        }
86        $zv=0;
[402]87        while($rowv = pg_fetch_assoc($resv)) {
[362]88                $ftyp=$rowv["ftyp"];
89                $gmlv=$rowv["gml_id"];
90                $vfsk=$rowv["flurstueckskennzeichen"];
91                echo "Flurst&uuml;ck <a title='Historie des Vorg&auml;ngerflurst&uuml;cks' href='".$_SERVER['PHP_SELF']."?gkz=".$gkz."&amp;fskennz=".$vfsk."&amp;gmlid=".$gmlv;
[377]92                        if ($showkey) {echo "&amp;showkey=j";}
[362]93                echo "'>".fzerleg($vfsk)."</a><br>";
94                $zv++;
95        }
[389]96        if ($zv == 0) {
97                echo "(keine)";
[400]98        }
[362]99        return;
100}
101
102session_start();
[402]103$showkey="n"; $nodebug=""; // Var. aus Parameter initalisieren
[387]104$cntget = extract($_GET); // alle Parameter in Variable umwandeln
105
106// strikte Validierung aller Parameter
107if (isset($gmlid)) {
108        if (!preg_match('#^[0-9A-Za-z]{16}$#', $gmlid)) {die("Eingabefehler gmlid");}
109        $fskennz='';
110} else { // Alternativ
111        $gmlid='';
112        if (isset($fskennz)) { // llgggg-fff-11111/222 oder z.B.'052647002001910013__' oder '05264700200012______'
113                if (!preg_match('#^[0-9\-_/]{8,20}$#', $fskennz)) {die ("Eingabefehler fskennz");}
114        } else {
115                $fskennz='';
116        }
117}
118if (!isset($gkz) or !preg_match('#^[0-9]{3}$#', $gkz)) {die("Eingabefehler gkz");}
119if (!preg_match('#^[j|n]{0,1}$#', $showkey)) {die ("Eingabefehler showkey");}
120if ($showkey == "j") {$showkey=true;} else {$showkey=false;} // "j"/"n" als boolean umwandeln, ist praktischer abzufragen, wird oft gebraucht
[402]121if (!preg_match('#^j{0,1}$#', $nodebug)) {die("Eingabefehler nodebug");}
[387]122
[362]123require_once("alkis_conf_location.php");
124if ($auth == "mapbender") {require_once($mapbender);}
125include("alkisfkt.php");
[402]126echo <<<END
[377]127<!doctype html>
128<html lang="de">
[362]129<head>
[377]130        <meta charset="utf-8">
[387]131        <meta name="viewport" content="width=device-width, initial-scale=1.0">
[362]132        <title>ALKIS Flurst&uuml;cks-Historie</title>
133        <link rel="stylesheet" type="text/css" href="alkisauszug.css">
134        <link rel="shortcut icon" type="image/x-icon" href="ico/Flurstueck_Historisch.ico">
135</head>
136<body>
[402]137END;
138// Mit URL-Parameter "&nodebug=j" kann man die Entwicklungsumgebung (in Conf definiert) ausschalten.
139// Manuell an die URL anfÌgen, wirkt nur temporÀr und wird nicht in Links weiter gereicht.
140if ($nodebug == "j") {$debug=0;}
141
[377]142$con = pg_connect($dbconn." options='--application_name=ALKIS-Auskunft_alkisfshist.php'");
[387]143if (!$con) echo "\n<p class='err'>Fehler beim Verbinden der DB</p>";
[362]144
145// Such-Parameter bekommen? Welche?
146if ($gmlid != "") { // Ja, die GML wurde uebergeben
147        $parmtyp="GML";
148        $parmval=$gmlid;
149        $whereclause="WHERE gml_id= $1 ";
150        $v = array($gmlid);
[377]151} elseif ($fskennz != "") { // Alternativ: Flurst.-Kennz. uebergeben
[362]152                $parmtyp="Flurst&uuml;ckskennzeichen";
153                $parmval=$fskennz;
154                $whereclause="WHERE flurstueckskennzeichen= $1 "; // hinten auffuellen mit _ auf 20 Stellen
155                $v = array($fskennz);
[377]156} else { // Pfui!
[362]157                $parmtyp="";
[389]158                die("<p class='err'>Parameter 'gmlid' oder 'fskennz' fehlt.</p>"); // Weitermachen sinnlos
[362]159}
160
161if ($parmtyp != "") { // einer der beiden erlaubten FÀlle
162        // UNION-Abfrage auf 3Àhnliche Tabellen, darin aber immer nur 1 Treffer.
[391]163        $felder="gml_id, flurnummer, cast(zaehler AS character varying), cast(nenner AS character varying), flurstueckskennzeichen, amtlicheflaeche, to_char(cast(zeitpunktderentstehung AS date),'DD.MM.YYYY') AS zeitpunktderentstehung, gemarkungsnummer, ";
[362]164
[377]165        if ($filtgem == '') { // Filter Gemeinde ?
166                $wheref='';
167                $whereh='';
168                $whereo='';
169        } else { // ZusÀtze zur WHERE-Clausel
[412]170                $wheref=" AND f.gemeindezugehoerigkeit_kreis = '".$filtkreis."' AND f.gemeindezugehoerigkeit_gemeinde = '".$filtgem."' ";
[417]171                $whereh=" AND (h.gemeindezugehoerigkeit_kreis IS NULL OR h.gemeindezugehoerigkeit_kreis = '".$filtkreis."' ) AND (h.gemeindezugehoerigkeit_gemeinde IS NULL OR h.gemeindezugehoerigkeit_gemeinde = '".$filtgem."') ";
172                $whereo=" AND (o.gemeindezugehoerigkeit_gemeinde IS NULL OR o.gemeindezugehoerigkeit_gemeinde = '".$filtgem."') ";
[377]173        }
[362]174
[417]175        $sqlu ="SELECT 'a' AS ftyp, ".$felder."null::character varying[] AS nach, null::character varying[] AS vor, zeigtaufexternes_art AS zart, zeigtaufexternes_name AS zname FROM ax_flurstueck f ".$whereclause.$wheref." AND f.endet IS NULL "
176        ."UNION SELECT 'h' AS ftyp, ".$felder."nachfolgerflurstueckskennzeichen AS nach, null AS vor, zeigtaufexternes_art AS zart, zeigtaufexternes_name AS zname FROM ax_historischesflurstueck h ".$whereclause.$whereh." AND h.endet IS NULL "
177        ."UNION SELECT 'o' AS ftyp, ".$felder."nachfolgerflurstueckskennzeichen AS nach, vorgaengerflurstueckskennzeichen AS vor, zeigtaufexternes_art AS zart, zeigtaufexternes_name AS zname FROM ax_historischesflurstueckohneraumbezug o ".$whereclause.$whereo." AND o.endet IS NULL;";
[377]178
[362]179        $resu = pg_prepare("", $sqlu);
180        $resu = pg_execute("", $v);
[402]181        if ($rowu = pg_fetch_assoc($resu)) {
[362]182                $ftyp=$rowu["ftyp"];
183                $gmkgnr=$rowu["gemarkungsnummer"];
184                $flurnummer=$rowu["flurnummer"];
185                $zaehler=$rowu["zaehler"];
186                $nenner=$rowu["nenner"];
187                $flstnummer=$zaehler;
188                if ($nenner > 0) {$flstnummer.="/".$nenner;} // BruchNr
189                $fskenn=$rowu["flurstueckskennzeichen"];
190                $flae=number_format($rowu["amtlicheflaeche"],0,",",".") . " m&#178;";
191                $gemkname= gemkg_name($gmkgnr);
192                $vor=$rowu["vor"];
193                $nach=$rowu["nach"];
[417]194                $entsteh=$rowu["zeitpunktderentstehung"];
195                $zeart=$rowu["zart"];
196                $zename=$rowu["zname"];
[362]197                if ($gmlid == "") {$gmlid=$rowu["gml_id"];} // fuer selbst-link-Umschalter ueber footer
[417]198
199                switch ($ftyp) { // Diff. Hist./Akt.
200                        case 'a':
201                                $wert = "aktuell";
202                                $ico= "Flurstueck.png";
203                                $cls= "kennzfs";       
204                        break;
205                        case 'h':
206                                $wert = "historisch<br>(mit Raumbezug)";
207                                $ico= "Flurstueck_Historisch.png"; //
208                                $cls= "kennzfsh";
209                        break;
210                        case 'o':
211                                $wert = "historisch<br>ohne Raumbezug";
212                                $ico= "Flurstueck_Historisch_oR.png";
213                                $cls= "kennzfsh";
214                        break;
215                        default:
216                                $wert = "<b>nicht gefunden: ".$parmtyp." = '".$parmval."'</b>";
217                                $ico= "Flurstueck_Historisch.png";
218                                $cls= "kennzfsh";
219                        break;
220                }
[362]221        } else {
[377]222                if ($debug > 1) {
223                        echo "<br><p class='err'>Fehler! Kein Treffer f&uuml;r ".$parmtyp." = '".$parmval."'</p><br>";
224                        if ($debug > 2) {
225                                echo "<p class='dbg'>SQL=<br>".$sqlu."<br>$1=".$parmtyp." = '".$parmval."'</p>";
226                        }
227                }
[362]228        }
229}
230
231// Balken
[387]232echo "<p class='fshis'>ALKIS Flurst&uuml;ck ".$gmkgnr."-".$flurnummer."-".$flstnummer."&nbsp;</p>";
[417]233echo "\n<h2>Flurst&uuml;ck Historie</h2>";
[362]234
[417]235echo "\n<table class='outer'>\n<tr>\n\t<td>"
236        ."\n\t<tr>\n\t\t<td class='ll'><img src='ico/".$ico."' width='16' height='16' alt=''> Kennzeichen:</td>" // Links
237        ."\n\t\t<td>" // Mitte
238        ."\n\t<table class='".$cls."' title='Flurst&uuml;ckskennzeichen'>\n\t<tr>" // innere Tabelle Kennzeichen
[402]239                ."\n\t\t<td class='head'>Gemarkung</td>\n\t\t<td class='head'>Flur</td>\n\t\t<td class='head'>Flurst-Nr.</td>\n\t</tr>"
[362]240                ."\n\t<tr>\n\t\t<td title='Gemarkung'>";
241                if ($showkey) {echo "<span class='key'>".$gmkgnr."</span><br>";}
242                echo $gemkname."&nbsp;</td>"
243                ."\n\t\t<td title='Flurnummer'>".$flurnummer."</td>"
244                ."\n\t\t<td title='Flurst&uuml;cksnummer (Z&auml;hler / Nenner)'><span class='wichtig'>".$flstnummer."</span></td>\n\t</tr>"
245        ."\n\t</table>"
[402]246."\n\t</td>\n\t<td>";
[417]247fortfuehrungen($entsteh, $zeart, $zename);
248echo "\n\t</td>\n</tr>\n</table>";
[362]249
250if ($ftyp == "a") { // Aktuell -> Historie
[377]251        echo "\n<p class='nwlink noprint'>weitere Auskunft: "
252                ."<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid."&amp;eig=n";
[362]253                        if ($showkey)   {echo "&amp;showkey=j";}
[377]254                        echo "' title='Flurst&uuml;cksnachweis'>Flurst&uuml;ck "
255                        ."<img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''>"
256                ."</a>";
[362]257}
[377]258echo "\n<hr>"
259."<table class='outer'>"
[362]260        ."\n<tr>
261                <td class='head'>Flurst&uuml;ck</td>
262                <td class='head'>Vorg&auml;nger</td>
263                <td class='head'>Nachfolger</td>
264        </tr>"; // Head
265       
266        // Spalte 1: F l u r s t ÃŒ c k
267        echo "\n<tr>\n\t<td>"
268                ."<img src='ico/".$ico."' width='16' height='16' alt=''> ".$wert
269                ."<br>Fl&auml;che <span class='flae'>".$flae."</span>"
270        ."</td>";
271
272        // Spalte 2: V o r g À n g e r
273        echo "\n\t<td>";
[417]274        switch ($ftyp) { // Diff. Hist./Akt.
[362]275                case 'a':
276                        such_vor_arr($fskenn);
277                break;
278                case 'h':
[417]279                        such_vor_arr($fskenn);
[362]280                break;
281                case 'o':
282                        vornach($vor);
283                break;
284        }
285        echo"</td>";
286
287        // Spalte 3: N a c h f o l g e r
288        echo "\n\t<td>";
289                vornach($nach);
290        echo "</td>\n</tr>"
291."\n</table>";
292
293if ($debug > 1) {
294        $z=1;
[402]295        while($rowu = pg_fetch_assoc($resu)) {
[362]296                $ftyp=$rowu["ftyp"];
297                echo "<p class='dbg'>Mehr als EIN Eintrag gefunden: '".$ftyp."' (".$z.")</p>";
298                $z++;
299        }
300}
301?>
302
[377]303<div class='buttonbereich noprint'>
304<hr>
305        <a title="zur&uuml;ck" href='javascript:history.back()'><img src="ico/zurueck.png" width="16" height="16" alt="zur&uuml;ck"></a>&nbsp;
306        <a title="Drucken" href='javascript:window.print()'><img src="ico/print.png" width="16" height="16" alt="Drucken"></a>&nbsp;
307</div>
[362]308
309<?php footer($gmlid, $_SERVER['PHP_SELF']."?", ""); ?>
310
311</body>
312</html>
Note: See TracBrowser for help on using the repository browser.