source: trunk/info/info/alkisn/alkisausk.php @ 389

Revision 389, 10.8 KB checked in by frank.jaeger, 3 years ago (diff)

ALKIS Buchauskunft überarbeitet: Bodenschätzung im FS-Nachweis. Filter auf "endet IS NULL".

Line 
1<?php
2/*      alkisausk.php
3
4        ALKIS-Buchauskunft, Kommunales Rechenzentrum Minden-Ravensberg/Lippe (Lemgo).
5        Dies Programm wird aus dem Mapserver-Template (FeatureInfo) aufgerufen.
6        Parameter: &gkz, &gml_id (optional &id)
7        Dies Programm gibt einen kurzen Überblick zum FlurstÃŒck, z.B. Eigentuemer ohne Adresse
8        FÃŒr detaillierte Angaben wird zum GB- oder FS-Nachweis verlinkt.
9        Siehe auch alkisinlayausk.php - eine Variante fÃŒr den Einbau in einen iFrame
10
11        Version:
12        2016-02-24 Version fuer norGIS-ALKIS-Import
13        2016-11-29 HTML5, Gemeinsam genutzte Datenbanken ermöglichen (Berechtigung fÃŒr Gemeinde prÃŒfen)
14        2017-10-11 Sauber filtern auf endet IS NULL
15
16        H i n w e i s :  Dies Modul wird beim Entwickler nicht mehr produktiv eingesetzt.
17                Statt dessen wird "alkisinlayausk.php" verwendet um von einer WMS-FeatureInfo in ein Fenster ÃŒberzuleiten.
18                Mangels Praxis bleiben Fehler möglicherweise unerkannt.
19*/
20session_start();
21$cntget = extract($_GET);
22
23require_once("alkis_conf_location.php");
24if ($auth == "mapbender") {require_once($mapbender);}
25include("alkisfkt.php");
26$keys = isset($_GET["showkey"]) ? $_GET["showkey"] : "n";
27if ($keys == "j") {$showkey=true;} else {$showkey=false;}
28echo <<<END
29<!doctype html>
30<html lang="de">
31<head>
32        <meta charset="utf-8">
33        <link rel="stylesheet" type="text/css" href="alkisauszug.css">
34        <link rel="shortcut icon" type="image/x-icon" href="ico/Flurstueck.ico">
35        <title>ALKIS-Auskunft</title>
36</head>
37<body>
38END;
39$con = pg_connect($dbconn." options='--application_name=ALKIS-Auskunft_alkisausk.php'");
40if (!$con) {echo "<br>Fehler beim Verbinden der DB.\n<br>";}
41
42// *** F L U R S T U E C K ***
43$sql ="SELECT f.flurnummer, f.zaehler, f.nenner, f.amtlicheflaeche, g.gemarkungsnummer, g.bezeichnung, f.regierungsbezirk, f.kreis, f.gemeinde
44FROM ax_flurstueck f LEFT JOIN ax_gemarkung g ON f.land=g.land AND f.gemarkungsnummer=g.gemarkungsnummer
45WHERE f.gml_id= $1 AND f.endet IS NULL AND g.endet IS NULL;";
46
47$v = array($gmlid);
48$res = pg_prepare("", $sql);
49$res = pg_execute("", $v);
50if (!$res) {
51        echo "\n<p class='err'>Fehler bei Flurstuecksdaten.</p>";
52        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
53}
54
55if ($row = pg_fetch_array($res)) {
56        $gemkname=htmlentities($row["bezeichnung"], ENT_QUOTES, "UTF-8");
57        $gmkgnr=$row["gemarkungsnummer"];
58        $flurnummer=$row["flurnummer"];
59        $flstnummer=$row["zaehler"];
60        $nenner=$row["nenner"];
61        if ($nenner > 0) $flstnummer.="/".$nenner; // BruchNr
62        $flae=$row["amtlicheflaeche"];
63        $flae=number_format($flae,0,",",".") . " m&#178;";
64        $fsreg=$row["regierungsbezirk"]; // Filter ZustÀndigkeit
65        $fskrs=$row["kreis"];
66        $fsgem=$row["gemeinde"];
67} else {
68        echo "\n<p class='err'>Kein Treffer fuer gml_id=".$gmlid."</p>";
69}
70
71// Balken
72echo "\n<p class='fsausk'>ALKIS-Auskunft Flurst&uuml;ck-&Uuml;bersicht ".$gmkgnr."-".$flurnummer."-".$flstnummer."</p>";
73
74// PrÃŒfung der Gebiets-Berechtigung bei gemeinsam genutzten Datenbanken (Kreis und Gemeinde)
75// FÃŒr das gkz (z.B. aus dem Mapfile-Namen) wird in der Konfiguration ein Filter gesetzt.
76if ( ($filtkreis != '' and $filtkreis != $fskrs) or ($filtgem != '' and $filtgem != $fsgem) ) {
77        // Einer der gesetzten Filter passt nicht
78        if ($debug > 2) {
79                echo "\n<p class='err'>Filter Kreis='".$filtkreis."', Gemeinde='".$filtgem."'</p>";
80                echo "\n<p class='err'>Flstk. Kreis='".$fskrs."', Gemeinde='".$fsgem."'</p>";
81        }
82        echo "\n<br><p class='stop1'>Zugriff nicht erlaubt</p>
83        \n<br><p class='stop2'>Dies Flurst&uuml;ck liegt ausserhalb der zust&auml;ndigen Stadt oder Gemeinde.</p>\n</body>\n</html>";
84        pg_free_result($res);
85        exit;
86}
87
88echo "\n<table class='outer'>\n<tr><td>";
89        // linke Seite
90        echo "\n<h1>ALKIS-Auskunft</h1>"
91        ."\n<h2><img src='ico/Flurstueck.png' width='16' height='16' alt=''> Flurst&uuml;ck - &Uuml;bersicht</h2>";
92echo "</td><td align='right'>";
93        // rechte Seite
94        echo "<img src='pic/AAA.gif' alt=''>"
95."</td></tr></table>";
96
97echo "\n<table class='outer'>\n<tr>\n<td>"
98        ."\n\t<table class='kennzfs' title='Flurst&uuml;ckskennzeichen'>\n\t<tr>"
99        ."\n\t\t<td class='head'>Gmkg</td>\n\t\t<td class='head'>Flur</td>\n\t\t<td class='head'>Flurst-Nr.</td>\n\t</tr>"
100        ."\n\t<tr>\n\t\t<td title='Gemarkung'>";
101        if ($showkey) {echo "<span class='key'>".$gmkgnr."</span><br>";}
102        echo $gemkname."</td>"
103        . "\n\t\t<td title='Flurnummer'>".$flurnummer."</td>"
104        ."\n\t\t<td title='Flurst&uuml;cksnummer (Z&auml;hler / Nenner)'><span class='wichtig'>".$flstnummer."</span></td>\n\t</tr>"
105        ."\n\t</table>"
106."\n</td>\n<td>"
107."\n\t<p class='nwlink'>weitere Auskunft:<br>";
108
109// Flurstuecksnachweis (o. Eigent.)
110echo "\n\t<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid."&amp;eig=n";
111        if ($showkey) {echo "&amp;showkey=j";}
112        echo "' title='Flurst&uuml;cksnachweis, alle Flurst&uuml;cksdaten'>Flurst&uuml;ck "
113        ."<img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''>"
114."</a><br>";
115
116// FS- u. Eigent.-NW
117echo "\n\t\t<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid."&amp;eig=j";
118        if ($showkey) {echo "&amp;showkey=j";}
119        echo "' title='Flurst&uuml;ck mit Eigent&uuml;mer'>Flurst&uuml;ck mit Eigent&uuml;mer "
120        ."<img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''>"
121."</a><br>";
122
123// FS-Historie
124echo "\n\t\t<a href='alkisfshist.php?gkz=".$gkz."&amp;gmlid=".$gmlid;
125        if ($showkey) {echo "&amp;showkey=j";}
126        echo "' title='Vorg&auml;nger des Flurst&uuml;cks'>Historie "
127        ."<img src='ico/Flurstueck_Historisch.png' width='16' height='16' alt=''>"
128."</a><br>";
129
130// Gebaeude-NW
131echo "\n\t\t<a href='alkisgebaeudenw.php?gkz=".$gkz."&amp;gmlid=".$gmlid;
132        if ($showkey) {echo "&amp;showkey=j";}
133        echo "' title='Geb&auml;udenachweis'>Geb&auml;ude "
134        ."<img src='ico/Haus.png' width='16' height='16' alt=''>"
135."</a>"
136. "\n\t</p>\n</td>";
137
138// Lagebezeichnung MIT Hausnummer (Adresse)
139$sql ="SELECT DISTINCT l.gml_id, s.gml_id AS kgml, l.gemeinde, l.lage, l.hausnummer, s.bezeichnung
140FROM ax_flurstueck f JOIN ax_lagebezeichnungmithausnummer l ON l.gml_id=ANY(f.weistauf)
141LEFT JOIN ax_lagebezeichnungkatalogeintrag s ON l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage
142WHERE f.gml_id= $1 AND f.endet IS NULL AND l.endet IS NULL AND s.endet IS NULL ORDER BY l.gemeinde, l.lage, l.hausnummer;";
143
144$v = array($gmlid);
145$res = pg_prepare("", $sql);
146$res = pg_execute("", $v);
147if (!$res) {
148        echo "\n<p class='err'>Fehler bei Lagebezeichnung mit Hausnummer.</p>";
149        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
150}
151$j=0;
152while($row = pg_fetch_array($res)) {
153        $sname = htmlentities($row["bezeichnung"], ENT_QUOTES, "UTF-8"); // Str.-Name
154        echo "\n<tr>\n\t"
155                ."\n\t<td class='lr'>".$sname."&nbsp;".$row["hausnummer"]."</td>"
156                ."\n\t<td>\n\t\t<p class='nwlink noprint'>"
157                        ."\n\t\t\t<a title='Lagebezeichnung mit Hausnummer' href='alkislage.php?gkz=".$gkz."&amp;ltyp=m&amp;gmlid=".$row["gml_id"]."'>Lage "
158                        ."<img src='ico/Lage_mit_Haus.png' width='16' height='16' alt=''></a>&nbsp;"
159                        ."\n\t\t\t<a href='alkisstrasse.php?gkz=".$gkz."&amp;gmlid=".$row["kgml"]
160                        ."' title='Stra&szlig;e'>Stra&szlig;e <img src='ico/Strassen.png' width='16' height='16' alt=''></a>"
161                ."\n\t\t</p>\n\t</td>"
162        ."\n</tr>";
163        $j++;
164}
165echo "\n</tr>\n</table>";
166
167// Flurstuecksflaeche
168echo "\n<p class='fsd'>Flurst&uuml;cksfl&auml;che: <b>".$flae."</b></p>";
169
170// *** G R U N D B U C H ***
171echo "\n<h2><img src='ico/Grundbuch_zu.png' width='16' height='16' alt=''> Grundbuch</h2>";
172// ALKIS: FS >istgebucht> GS >istBestandteilVon> GB.
173$sql ="SELECT b.gml_id, b.bezirk, b.buchungsblattnummermitbuchstabenerweiterung as blatt, b.blattart, wa.v AS blattartv,
174s.gml_id AS s_gml, s.buchungsart, s.laufendenummer, s.zaehler, s.nenner, z.bezeichnung, wb.v AS bart
175FROM ax_flurstueck f
176JOIN ax_buchungsstelle s ON f.istgebucht=s.gml_id
177JOIN ax_buchungsblatt b ON s.istbestandteilvon=b.gml_id
178LEFT JOIN ax_buchungsblattbezirk z ON z.land=b.land AND z.bezirk=b.bezirk
179LEFT JOIN alkis_wertearten wa ON cast(b.blattart AS character varying)=wa.k AND wa.element='ax_buchungsblatt' AND wa.bezeichnung='blattart'
180LEFT JOIN alkis_wertearten wb ON cast(s.buchungsart AS character varying)=wb.k AND wb.element='ax_buchungsstelle' AND wb.bezeichnung='buchungsart'
181WHERE f.gml_id= $1 AND f.endet IS NULL AND s.endet IS NULL AND b.endet IS NULL AND z.endet IS NULL
182ORDER BY b.bezirk, b.buchungsblattnummermitbuchstabenerweiterung, s.laufendenummer;";
183
184$v = array($gmlid);
185$resg = pg_prepare("", $sql);
186$resg = pg_execute("", $v);
187if (!$resg) {
188        echo "\n<p class='err'>Keine Buchungen.</p>";
189        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
190}
191
192$j=0; // Z.Blatt
193while($rowg = pg_fetch_array($resg)) {
194        $beznam=$rowg["bezeichnung"];
195        echo "\n<table class='outer'>\n<tr>\n<td>";
196                $blattkey=$rowg["blattart"];
197                $blattart=$rowg["blattartv"];
198                if ($blattkey == 1000) {
199                        echo "\n\t<table class='kennzgb' title='Bestandskennzeichen'>";
200                } else {
201                        echo "\n\t<table class='kennzgbf' title='Bestandskennzeichen'>"; // dotted
202                }
203                        echo "\n\t<tr>"
204                                ."\n\t\t<td class='head'>Bezirk</td>"
205                                ."\n\t\t<td class='head'>".$blattart."</td>"
206                                ."\n\t\t<td class='head'>Lfd-Nr.</td>"
207                                ."\n\t\t<td class='head'>Buchungsart</td>"
208                        ."\n\t</tr>";
209                        echo "\n\t<tr>"
210                                ."\n\t\t<td title='Grundbuchbezirk'>";
211                                        if ($showkey) {echo "<span class='key'>".$rowg["bezirk"]."</span><br>";}
212                                echo $beznam."</td>"
213                                ."\n\t\t<td title='Grundbuch-Blatt'><span class='wichtig'>".$rowg["blatt"]."</span></td>"
214                                ."\n\t\t<td title='Bestandsverzeichnis-Nummer (BVNR, Grundst&uuml;ck)'>".$rowg["laufendenummer"]."</td>"
215                                ."\n\t\t<td title='Buchungsart'>";
216                                        if ($showkey) {echo "<span class='key'>".$rowg["buchungsart"]."</span><br>";}
217                                        echo $rowg["bart"]
218                                ."</td>"
219                        ."\n\t</tr>"
220                ."\n\t</table>";
221
222                if ($rowg["zaehler"] <> "") {
223                        echo "\n<p class='ant'>".$rowg["zaehler"]."/".$rowg["nenner"]."&nbsp;Anteil am Flurst&uuml;ck</p>";
224                }
225                echo "\n</td>\n<td>"
226                ."\n\t<p class='nwlink'>weitere Auskunft:<br>"
227                        ."\n\t\t<a href='alkisbestnw.php?gkz=".$gkz."&amp;gmlid=".$rowg[0];
228                                if ($showkey) {echo "&amp;showkey=j";}
229                                echo "' title='Grundbuchnachweis'>".$blattart." <img src='ico/GBBlatt_link.png' width='16' height='16' alt=''>"
230                        ."</a>"
231                ."\n\t</p>"
232        ."\n</td>\n</tr>\n</table>";
233
234        // E I G E N T U E M E R
235        if ($blattkey == 5000) { // SchlÃŒssel Blatt-Art
236                echo "\n<p>Keine Angaben zum Eigentum bei fiktivem Blatt</p>\n"
237                ."\n<p>Siehe weitere Grundbuchbl&auml;tter mit Rechten an dem fiktiven Blatt.</p>";
238        } else { // kein Eigent. bei fiktiv. Blatt
239                // Ausgabe Name in Function
240                $n = eigentuemer($rowg["gml_id"], false, "imFenster"); // ohne Adressen
241
242                if ($n == 0) { // keine NamNum, kein Eigent.
243                        echo "\n<p class='err'>Keine Eigent&uuml;mer gefunden.</p>"
244                        ."\n<p class='err'>Bezirk ".$rowg["bezirk"]." Blatt ".$rowg["blatt"]." Blattart ".$blattkey." (".$blattart.")</p>";
245                }
246        }
247        $j++;
248}
249if ($j == 0) {echo "\n<p class='err'>Keine Buchungen gefunden.</p>";}
250echo "\n<hr>";
251
252footer($gmlid, $_SERVER['PHP_SELF']."?", "");
253
254?>
255</body>
256</html>
Note: See TracBrowser for help on using the repository browser.