[41] | 1 | <?php
|
---|
| 2 | /* alkislage.php
|
---|
[123] | 3 |
|
---|
[41] | 4 | ALKIS-Buchauskunft, Kommunales Rechenzentrum Minden-Ravensberg/Lippe (Lemgo).
|
---|
| 5 | Kann die 3 Arten von Lagebezeichnung anzeigen und verbundene Objekte verlinken
|
---|
[45] | 6 |
|
---|
[123] | 7 | Version:
|
---|
| 8 | 11.07.2011 Ersetzen $self durch $_SERVER['PHP_SELF']."?"
|
---|
| 9 | 25.07.2011 PostNAS 0.5/0.6 Versionen unterscheiden
|
---|
| 10 | 26.07.2011 debug, SQL nur im Testmodeus ausgeben
|
---|
| 11 |
|
---|
[81] | 12 | ToDo: Entschluesseln Kreis usw.
|
---|
[41] | 13 | */
|
---|
[105] | 14 | //ini_set('error_reporting', 'E_ALL & ~ E_NOTICE');
|
---|
[123] | 15 | session_start();
|
---|
[60] | 16 | $gkz=urldecode($_REQUEST["gkz"]);
|
---|
[123] | 17 | require_once("alkis_conf_location.php");
|
---|
[105] | 18 | if ($auth == "mapbender") { // Bindung an Mapbender-Authentifizierung
|
---|
[49] | 19 | require_once($mapbender);
|
---|
| 20 | }
|
---|
[41] | 21 | include("alkisfkt.php");
|
---|
| 22 | ?>
|
---|
| 23 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
---|
| 24 | <html>
|
---|
| 25 | <head>
|
---|
[49] | 26 | <meta name="author" content="F. Jaeger krz" >
|
---|
[41] | 27 | <meta http-equiv="cache-control" content="no-cache">
|
---|
| 28 | <meta http-equiv="pragma" content="no-cache">
|
---|
| 29 | <meta http-equiv="expires" content="0">
|
---|
| 30 | <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
|
---|
| 31 | <title>ALKIS Lagebezeichnung</title>
|
---|
[123] | 32 | <link rel="stylesheet" type="text/css" href="alkisauszug.css">
|
---|
[41] | 33 | <link rel="shortcut icon" type="image/x-icon" href="ico/Lage_mit_Haus.ico">
|
---|
| 34 | <style type='text/css' media='print'>
|
---|
[60] | 35 | .noprint {visibility: hidden;}
|
---|
[41] | 36 | </style>
|
---|
| 37 | </head>
|
---|
| 38 | <body>
|
---|
| 39 | <?php
|
---|
| 40 | $gmlid=urldecode($_REQUEST["gmlid"]);
|
---|
[123] | 41 | $ltyp=urldecode($_REQUEST["ltyp"]); // 3 Arten Lage-Typ
|
---|
[41] | 42 | switch ($ltyp) {
|
---|
| 43 | case "m": // "Mit HsNr" = Hauptgebaeude
|
---|
| 44 | $tnam = "ax_lagebezeichnungmithausnummer";
|
---|
| 45 | break;
|
---|
| 46 | case "p": // "mit PseudoNr" = Nebengebaeude
|
---|
| 47 | $tnam = "ax_lagebezeichnungmitpseudonummer";
|
---|
| 48 | break;
|
---|
| 49 | case "o": //"Ohne HsNr" = Gewanne oder Strasse
|
---|
| 50 | $tnam = "ax_lagebezeichnungohnehausnummer";
|
---|
| 51 | break;
|
---|
| 52 | default:
|
---|
[123] | 53 | $ltyp = "m";
|
---|
[41] | 54 | $tnam = "ax_lagebezeichnungmithausnummer";
|
---|
| 55 | break;
|
---|
[43] | 56 | }
|
---|
[123] | 57 | $id = isset($_GET["id"]) ? $_GET["id"] : "n";
|
---|
| 58 | if ($id == "j") {
|
---|
| 59 | $idanzeige=true;
|
---|
| 60 | } else {
|
---|
| 61 | $idanzeige=false;
|
---|
| 62 | }
|
---|
[43] | 63 | $keys = isset($_GET["showkey"]) ? $_GET["showkey"] : "n";
|
---|
[123] | 64 | if ($keys == "j") {
|
---|
| 65 | $showkey=true;
|
---|
| 66 | } else {
|
---|
| 67 | $showkey=false;
|
---|
[43] | 68 | }
$con = pg_connect("host=".$dbhost." port=" .$dbport." dbname=".$dbname." user=".$dbuser." password=".$dbpass);
|
---|
[41] | 69 | if (!$con) echo "<p class='err'>Fehler beim Verbinden der DB</p>\n";
|
---|
[123] | 70 |
|
---|
| 71 | // Lagebezeichnung
|
---|
[41] | 72 | $sql ="SELECT s.bezeichnung AS snam, k.bezeichnung AS knam, g.bezeichnung AS gnam, l.land, l.regierungsbezirk, l.kreis, l.gemeinde, l.lage, ";
|
---|
[123] | 73 | switch ($ltyp) {
|
---|
[41] | 74 | case "m": // "Mit HsNr"
|
---|
| 75 | $sql.="l.hausnummer ";
|
---|
| 76 | break;
|
---|
| 77 | case "p": // "mit PseudoNr"
|
---|
| 78 | $sql.="l.pseudonummer, l.laufendenummer ";
|
---|
| 79 | break;
|
---|
| 80 | case "o": //"Ohne HsNr"
|
---|
| 81 | $sql.="l.unverschluesselt ";
|
---|
| 82 | break;
|
---|
| 83 | }
|
---|
[123] | 84 | $sql.="FROM ".$tnam." l ";
|
---|
| 85 | // Gemeinde, Kreis, Strasse entschluesseln
|
---|
| 86 | $sql.="LEFT JOIN ax_gemeinde g ON l.land=g.land AND l.regierungsbezirk=g.regierungsbezirk AND l.kreis=g.kreis AND l.gemeinde=g.gemeinde ";
|
---|
[81] | 87 | $sql.="LEFT JOIN ax_kreisregion k ON l.land=k.land AND l.regierungsbezirk=k.regierungsbezirk AND l.kreis=k.kreis ";
|
---|
[123] | 88 | $sql.="LEFT JOIN ax_lagebezeichnungkatalogeintrag s ";
|
---|
| 89 |
|
---|
| 90 | if ($dbvers == "05") { // bis PostNAS 0.5
|
---|
| 91 | // Besonderheit: unterschiedliche Feldformate und Fuellungen!!!
|
---|
| 92 | // +++ Nach vollstaendiger Umstellung diesen Programmteil entfernen
|
---|
| 93 | switch ($ltyp) {
|
---|
[105] | 94 | case "o": //"Ohne HsNr"
|
---|
| 95 | // hier beide .lage als Char(5)
|
---|
[123] | 96 | // in ax_lagebezeichnungKatalogeintrag mit fÃŒhrenden Nullen
|
---|
| 97 | // in ax_lagebezeichnungOhneHausnummer jedoch ohne fÃŒhrende Nullen
|
---|
| 98 | $sql.="ON l.land=s.land AND l.regierungsbezirk=s.regierungsbezirk AND l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=trim(leading '0' from s.lage) ";
|
---|
| 99 | break;
|
---|
| 100 | default: // "Mit HsNr" + "mit PseudoNr"
|
---|
| 101 | // ax_LagebezeichnungKatalogeintrag.lage ist char,
|
---|
| 102 | // ax_LagebezeichnungMitHausnummer.lage ist integer,
|
---|
[105] | 103 | // ax_lagebezeichnungMitPseudonummer.lage ist integer,
|
---|
[123] | 104 | $sql.="ON l.land=s.land AND l.regierungsbezirk=s.regierungsbezirk AND l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND to_char(l.lage, 'FM00000')=s.lage ";
|
---|
| 105 | break;
|
---|
[105] | 106 | }
|
---|
[123] | 107 | } else { // ab PostNAS 0.6 char(5) mit fuehr.Nullen
|
---|
| 108 | $sql.="ON l.land=s.land AND l.regierungsbezirk=s.regierungsbezirk AND l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage ";
|
---|
| 109 | }
|
---|
| 110 | $sql.="WHERE l.gml_id= $1;";
|
---|
[61] | 111 |
|
---|
| 112 | $v = array($gmlid);
|
---|
| 113 | $res = pg_prepare("", $sql);
|
---|
| 114 | $res = pg_execute("", $v);
|
---|
[123] | 115 | if (!$res) {
|
---|
| 116 | echo "\n<p class='err'>Fehler bei Lagebezeichnung.</p>\n";
|
---|
| 117 | if ($debug > 2) {echo "<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
|
---|
| 118 | }
|
---|
| 119 |
|
---|
[61] | 120 | if ($row = pg_fetch_array($res)) {
|
---|
[123] | 121 | $land =$row["land"];
|
---|
| 122 | $regbez=$row["regierungsbezirk"];
|
---|
[41] | 123 | $kreis=$row["kreis"];
|
---|
[123] | 124 | $knam=$row["knam"];
|
---|
| 125 | $gem =$row["gemeinde"];
|
---|
| 126 | $gnam =$row["gnam"];
|
---|
| 127 | $lage =$row["lage"]; // Strassenschluessel
|
---|
| 128 | $snam =$row["snam"]; //Strassennamen
|
---|
| 129 | $unver=$row["unverschluesselt"]; // Gewanne
|
---|
| 130 | $kennz=$land."-".$regbez."-".$kreis."-".$gem."-".$lage."-";
|
---|
| 131 | switch ($ltyp) {
|
---|
[41] | 132 | case "m": // "Mit HsNr"
|
---|
| 133 | $hsnr=$row["hausnummer"];
|
---|
[123] | 134 | $kennz.=$hsnr;
|
---|
| 135 | $untertitel="Hauptgebäude mit Hausnummer";
|
---|
| 136 | // Balken
|
---|
| 137 | echo "<p class='lage'>ALKIS Lagebezeichnung mit Hausnummer ".$kennz." </p>\n"; // Balken
|
---|
[43] | 138 | break;
|
---|
[41] | 139 | case "p": // "mit PseudoNr"
|
---|
| 140 | $pseu=$row["pseudonummer"];
|
---|
[123] | 141 | $lfd=$row["laufendenummer"];
|
---|
| 142 | $kennz.=$pseu."-".$lfd;
|
---|
| 143 | $untertitel="NebengebÀude mit laufender Nummer (Lagebezeichnung mit Pseudonummer)";
|
---|
[64] | 144 | echo "<p class='lage'>ALKIS Lagebezeichnung NebengebÀude ".$kennz." </p>\n"; // Balken
|
---|
[123] | 145 | break;
|
---|
[41] | 146 | case "o": //"Ohne HsNr"
|
---|
[123] | 147 | if ($lage == "") {
|
---|
| 148 | $kennz=" - ".$unver;
|
---|
| 149 | } else {
|
---|
| 150 | $kennz.=$unver;
}
$untertitel="Straße ohne Hausnummer und/oder Gewanne (unverschlüsselte Lage)";
|
---|
[64] | 151 | echo "<p class='lage'>ALKIS Lagebezeichnung Ohne Hausnummer ".$kennz." </p>\n"; // Balken
|
---|
[41] | 152 | break;
|
---|
[64] | 153 | }
|
---|
[43] | 154 | } else {
|
---|
[41] | 155 | echo "<p class='err'>Fehler! Kein Treffer fuer gml_id=".$gmlid."</p>";
|
---|
[123] | 156 | }
|
---|
| 157 |
|
---|
| 158 | echo "\n<h2><img src='ico/Lage_mit_Haus.ico' width='16' height='16' alt=''> Lagebezeichnung</h2>\n";
|
---|
[41] | 159 |
|
---|
[123] | 160 | echo "<p>Typ: ".$untertitel."</p>";
|
---|
[41] | 161 |
|
---|
[123] | 162 | echo "\n<table class='outer'>\n<tr>\n\t<td>"; // Tabelle Kennzeichen
|
---|
| 163 | // ToDo: !! kleiner, wenn ltyp=0 und die Schluesselfelder leer sind
|
---|
| 164 | echo "\n\t<table class='kennzla' title='Lage'>";
|
---|
[81] | 165 | echo "\n\t<tr>";
|
---|
[41] | 166 | echo "\n\t\t<td class='head'>Land</td>";
|
---|
[123] | 167 | echo "\n\t\t<td class='head'>Reg.-Bez.</td>";
|
---|
[41] | 168 | echo "\n\t\t<td class='head'>Kreis</td>";
|
---|
[123] | 169 | echo "\n\t\t<td class='head'>Gemeinde</td>";
|
---|
| 170 | echo "\n\t\t<td class='head'>Straße</td>";
|
---|
| 171 | switch ($ltyp) {
|
---|
| 172 | case "m": // "Mit HsNr"
|
---|
| 173 | echo "\n\t\t<td class='head'>Haus-Nr</td>";
|
---|
[41] | 174 | break;
|
---|
| 175 | case "p": // "mit PseudoNr"
|
---|
| 176 | echo "\n\t\t<td class='head'>Haus-Nr</td>";
|
---|
| 177 | echo "\n\t\t<td class='head'>lfd.-Nr</td>";
|
---|
| 178 | break;
|
---|
[123] | 179 | case "o": //"Ohne HsNr"
|
---|
[64] | 180 | echo "\n\t\t<td class='head'>unverschlüsselte Lage</td>";
|
---|
[41] | 181 | break;
|
---|
| 182 | }
|
---|
| 183 | echo "\n\t</tr>";
|
---|
| 184 | echo "\n\t<tr>";
|
---|
[123] | 185 | echo "\n\t\t<td title='Bundesland'>".$land."</td>";
|
---|
[41] | 186 | echo "\n\t\t<td title='Regierungsbezirk'>".$regbez."</td>";
|
---|
[123] | 187 | echo "\n\t\t<td title='Kreis'>";
|
---|
[41] | 188 | if ($showkey) {
|
---|
| 189 | echo "<span class='key'>".$kreis."</span><br>";
|
---|
[123] | 190 | }
|
---|
| 191 | echo $knam." </td>";
|
---|
| 192 | echo "\n\t\t<td title='Gemeinde'>";
|
---|
| 193 | if ($showkey) {
|
---|
| 194 | echo "<span class='key'>".$gem."</span><br>";
|
---|
| 195 | }
|
---|
| 196 | echo $gnam." </td>";
|
---|
| 197 | echo "\n\t\t<td title='Straße'>";
|
---|
| 198 | if ($showkey) {
|
---|
| 199 | echo "<span class='key'>".$lage."</span><br>";
|
---|
| 200 | }
|
---|
| 201 | echo $snam." </td>";
|
---|
| 202 | switch ($ltyp) {
|
---|
| 203 | case "m":
|
---|
| 204 | echo "\n\t\t<td title='Hausnummer und Zusatz'><span class='wichtig'>".$hsnr."</span></td>";
|
---|
[41] | 205 | break;
|
---|
| 206 | case "p":
|
---|
| 207 | echo "\n\t\t<td title='Pseudonummer - Nebengebäude zu dieser Hausnummer'>".$pseu."</td>";
|
---|
| 208 | echo "\n\t\t<td title='Laufende Nummer Nebengebäude'><span class='wichtig'>".$lfd."</span></td>";
|
---|
| 209 | break;
|
---|
[123] | 210 | case "o":
|
---|
[41] | 211 | echo "\n\t\t<td title='Gewanne'><span class='wichtig'>".$unver."</span></td>";
|
---|
| 212 | break;
|
---|
| 213 | }
|
---|
| 214 | echo "\n\t</tr>";
|
---|
| 215 | echo "\n\t</table>";
|
---|
[123] | 216 |
|
---|
[41] | 217 | echo "\n\t</td>\n\t<td>";
|
---|
| 218 |
|
---|
| 219 | // Kopf Rechts: weitere Daten?
|
---|
| 220 | // z.B. hier Ausgabe von "georeferenzierte GebÀudeadresse" ?
|
---|
[123] | 221 | if ($idanzeige) {linkgml($gkz, $gmlid, "Lage"); }
|
---|
| 222 |
|
---|
[64] | 223 | echo "\n\t</td>\n</tr>\n</table>";
|
---|
[43] | 224 | // Ende Seitenkopf
|
---|
[123] | 225 |
|
---|
[41] | 226 | // F L U R S T U E C K E
|
---|
[123] | 227 | if ($ltyp <> "p") { // Pseudonummer linkt nur GebÀude
|
---|
| 228 | echo "\n\n<a name='fs'></a><h3><img src='ico/Flurstueck.ico' width='16' height='16' alt=''> Flurstücke</h3>\n";
|
---|
| 229 | echo "\n<p>mit dieser Lagebezeichnung.</p>";
|
---|
| 230 | // ax_Flurstueck >weistAuf> ax_LagebezeichnungMitHausnummer
|
---|
| 231 | // ax_Flurstueck >zeigtAuf> ax_LagebezeichnungOhneHausnummer
|
---|
| 232 | switch ($ltyp) {
|
---|
| 233 | case "m":
|
---|
| 234 | $bezart="weistAuf";
|
---|
[41] | 235 | break;
|
---|
| 236 | case "o":
|
---|
| 237 | $bezart="zeigtAuf";
|
---|
| 238 | break;
|
---|
| 239 | }
|
---|
| 240 | $sql="SELECT g.gemarkungsnummer, g.bezeichnung, ";
|
---|
| 241 | $sql.="f.gml_id, f.flurnummer, f.zaehler, f.nenner, f.regierungsbezirk, f.kreis, f.gemeinde, f.amtlicheflaeche ";
|
---|
[123] | 242 | $sql.="FROM ax_flurstueck f ";
|
---|
[41] | 243 | $sql.="JOIN alkis_beziehungen v ON f.gml_id=v.beziehung_von ";
|
---|
[123] | 244 | $sql.="LEFT JOIN ax_gemarkung g ON f.land=g.land AND f.gemarkungsnummer=g.gemarkungsnummer ";
|
---|
[78] | 245 | $sql.="WHERE v.beziehung_zu= $1 "; // id Lage
|
---|
[41] | 246 | $sql.="AND v.beziehungsart= $2 ";
|
---|
[123] | 247 | $sql.="ORDER BY f.gemarkungsnummer, f.flurnummer, f.zaehler, f.nenner;";
|
---|
[61] | 248 |
|
---|
| 249 | $v = array($gmlid,$bezart);
|
---|
[123] | 250 | $resf = pg_prepare("", $sql);
|
---|
[61] | 251 | $resf = pg_execute("", $v);
|
---|
| 252 | if (!$resf) {
|
---|
| 253 | echo "<p class='err'>Fehler bei Flurstück.</p>\n";
|
---|
[123] | 254 | if ($debug > 2) {echo "<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
|
---|
| 255 | }
|
---|
| 256 |
|
---|
| 257 | echo "\n<table class='fs'>";
|
---|
| 258 | echo "\n<tr>"; // Kopfzeile der Tabelle
|
---|
[61] | 259 | echo "\n\t<td class='head'>Gemarkung</td>";
|
---|
[41] | 260 | echo "\n\t<td class='head'>Flur</td>";
|
---|
| 261 | echo "\n\t<td class='head' title='Flurstücksnummer (Zähler / Nenner)'>Flurst.</td>";
|
---|
| 262 | echo "\n\t<td class='head fla'>Fläche</td>";
|
---|
| 263 | echo "\n\t<td class='head nwlink noprint' title='Link: weitere Auskunft'>weit. Auskunft</td>";
|
---|
| 264 | echo "\n</tr>";
|
---|
| 265 | $j=0;
|
---|
[123] | 266 | while($rowf = pg_fetch_array($resf)) {
|
---|
| 267 | $flur=str_pad($rowf["flurnummer"], 3, "0", STR_PAD_LEFT);
|
---|
| 268 |
|
---|
[45] | 269 | //$fskenn=str_pad($rowf["zaehler"], 5, "0", STR_PAD_LEFT);
|
---|
[123] | 270 | //if ($rowf["nenner"] != "") {$fskenn.="/".str_pad($rowf["nenner"], 3, "0", STR_PAD_LEFT);}
|
---|
| 271 |
|
---|
| 272 | $fskenn=$rowf["zaehler"]; // Bruchnummer (ohne fuehrende Nullen)
|
---|
| 273 | if ($rowf["nenner"] != "") {
|
---|
| 274 | $fskenn.="/".$rowf["nenner"];
|
---|
| 275 | }
|
---|
| 276 |
|
---|
| 277 | $flae=number_format($rowf["amtlicheflaeche"],0,",",".") . " m²";
|
---|
| 278 | echo "\n<tr>";
echo "\n\t<td>";
|
---|
| 279 | if ($showkey) {
|
---|
| 280 | echo "<span class='key'>".$rowf["gemarkungsnummer"]."</span> ";
|
---|
[41] | 281 | }
|
---|
[123] | 282 | echo $rowf["bezeichnung"]."</td>";
|
---|
| 283 | echo "\n\t<td>".$flur."</td>";
|
---|
| 284 | echo "\n\t<td><span class='wichtig'>".$fskenn."</span>";
|
---|
| 285 | if ($idanzeige) {linkgml($gkz, $rowf["gml_id"], "Flurstück");}
|
---|
[43] | 286 | echo "</td>";
|
---|
[41] | 287 | echo "\n\t<td class='fla'>".$flae."</td>";
|
---|
[43] | 288 | echo "\n\t<td>\n\t\t<p class='nwlink noprint'>";
|
---|
| 289 | echo "\n\t\t<a href='alkisfsnw.php?gkz=".$gkz."&gmlid=".$rowf["gml_id"]."&eig=n";
|
---|
[123] | 290 | if ($idanzeige) {echo "&id=j";}
|
---|
[43] | 291 | if ($showkey) {echo "&showkey=j";}
|
---|
| 292 | echo "' title='Flurstücksnachweis'>Flurstück <img src='ico/Flurstueck_Link.ico' width='16' height='16' alt=''></a>";
|
---|
| 293 | echo "\n\t\t</p>\n\t</td>";
|
---|
| 294 | echo "\n</tr>";
|
---|
[123] | 295 | $j++;
|
---|
| 296 | }
|
---|
| 297 | echo "\n</table>";
|
---|
[41] | 298 | }
|
---|
| 299 |
|
---|
[123] | 300 | // L A G E
|
---|
| 301 | // andere Lage mit gleicher Hausnummer suchen
|
---|
| 302 | if ($ltyp <> "o") { // nicht bei Gewanne (Ohne HsNr)
|
---|
| 303 | echo "\n\n<a name='lage'></a><h3><img src='ico/Lage_mit_Haus.ico' width='16' height='16' alt=''> Lage</h3>\n";
|
---|
| 304 | echo "\n<p>andere Lagebezeichnungen zur gleichen Hausnummer.</p>";
|
---|
| 305 | $whereclaus="WHERE land= $1 AND regierungsbezirk= $2 AND kreis= $3 AND gemeinde= $4 AND lage= $5 ";
|
---|
| 306 | $url=$_SERVER['PHP_SELF']."?gkz=".$gkz."&id=".$id."&gmlid="; // Basis
|
---|
| 307 |
|
---|
| 308 | switch ($ltyp) {
|
---|
| 309 | case "m": // aktuell Hausnummer gefunden
|
---|
| 310 | // dazu alle NebengebÀude suchen
|
---|
| 311 | echo "\n<p>Nebengebäude: ";
|
---|
[41] | 312 | $sql ="SELECT l.gml_id, l.laufendenummer FROM ax_lagebezeichnungmitpseudonummer l ";
|
---|
[123] | 313 | $sql.=$whereclaus."AND lage= $6 AND pseudonummer= $7 ORDER BY laufendenummer;";
|
---|
| 314 | // pseudonummer character varying(5), laufendenummer character varying(2),
|
---|
| 315 |
|
---|
| 316 | $v = array($land,$regbez,$kreis,$gem,$lage,$lage,$hsnr);
|
---|
| 317 | $res = pg_prepare("", $sql);
|
---|
[61] | 318 | $res = pg_execute("", $v);
|
---|
[64] | 319 | if (!$res) {
|
---|
[61] | 320 | echo "\n<p class='err'>Fehler bei Nebengebäude.<br>".$sql."</p>\n";
|
---|
| 321 | if ($debug > 2) {echo "<p class='err'>SQL=<br>".$sql."</p>";}
|
---|
[123] | 322 | }
|
---|
| 323 | while($row = pg_fetch_array($res)) {
|
---|
| 324 | echo "\n\t<a href='".$url.$row["gml_id"]."&ltyp=p'>lfd.-Nr ".$row["laufendenummer"]."</a> ";
|
---|
| 325 | }
|
---|
| 326 | echo "\n</p>";
|
---|
| 327 | break;
|
---|
| 328 |
|
---|
| 329 | case "p": // aktuell NebengebÀude: Haupt- und NebengebÀude suchen
|
---|
[43] | 330 | echo "\n<p>Hauptgebäude: ";
|
---|
[41] | 331 | $sql ="SELECT l.gml_id FROM ax_lagebezeichnungmithausnummer l ";
|
---|
[123] | 332 | $sql.=$whereclaus."AND hausnummer= $6;";
|
---|
[41] | 333 |
|
---|
[123] | 334 | $v = array($land,$regbez,$kreis,$gem,$lage,$pseu);
|
---|
| 335 | $res = pg_prepare("", $sql);
|
---|
[61] | 336 | $res = pg_execute("", $v);
|
---|
[64] | 337 |
|
---|
[61] | 338 | if (!$res) echo "<p class='err'>Fehler bei Hauptgebäude.<br>".$sql."</p>\n";
|
---|
| 339 | while($row = pg_fetch_array($res)) {
|
---|
[123] | 340 | echo "\n\t<a href='".$url.$row["gml_id"]."&ltyp=m'>Haus-Nr ".$pseu."</a> ";
|
---|
[64] | 341 | }
|
---|
[123] | 342 | echo "\n</p>";
|
---|
| 343 |
|
---|
| 344 | echo "\n<p>weitere Nebengebäude: ";
|
---|
| 345 | $sql ="SELECT l.gml_id, l.laufendenummer FROM ax_lagebezeichnungmitpseudonummer l ";
|
---|
| 346 | $sql.=$whereclaus."AND pseudonummer= $6 AND laufendenummer <> $7 ORDER BY laufendenummer;";
|
---|
| 347 | $v = array($land,$regbez,$kreis,$gem,$lage,$pseu,$lfd);
|
---|
| 348 | $res = pg_prepare("", $sql);
|
---|
| 349 | $res = pg_execute("", $v);
|
---|
[61] | 350 | if (!$res) {
|
---|
| 351 | echo "\n<p class='err'>Fehler bei Nebengebäude.</p>\n";
|
---|
| 352 | if ($debug > 2) {echo "<p class='err'>SQL=<br>".$sql."</p>";}
|
---|
[123] | 353 | }
|
---|
| 354 | while($row = pg_fetch_array($res)) {
|
---|
| 355 | echo "\n\t<a href='".$url.$row["gml_id"]."&ltyp=p'>lfd.-Nr ".$row["laufendenummer"]."</a> ";
|
---|
| 356 | }
|
---|
[41] | 357 | echo "\n</p>";
|
---|
[123] | 358 | break;
}
|
---|
| 359 | }
|
---|
| 360 |
|
---|
| 361 | // G E B A E U D E
|
---|
[41] | 362 |
|
---|
[123] | 363 | // Mittelfristig ist zu ueberlegen, ob hier weitere Einzelheiten dargestellt werden,
|
---|
| 364 | // oder ob nicht besser ein eigenes Modul alkisgebaeude.php dies uebernehmen sollte.
|
---|
| 365 | // Dort sollten auch diese Relationen abgebildet werden:
|
---|
| 366 | // ax_gebaeude >gehoertZu> ax_gebaeude (ringförmige Verbindung GebÀudekomplex)
|
---|
| 367 | // ax_gebaeude (umschliesst) ax_bauteil
|
---|
| 368 | // ax_gebaeude >gehoert> ax_person (Ausnahme)
|
---|
| 369 |
|
---|
| 370 | if ($ltyp <> "o") { // OhneHsNr linkt nur Flurst.
|
---|
| 371 | echo "\n\n<a name='geb'></a><h3><img src='ico/Haus.ico' width='16' height='16' alt=''> Gebäude</h3>";
|
---|
| 372 | echo "\n<p>mit dieser Lagebezeichnung.</p>";
|
---|
| 373 | switch ($ltyp) {
|
---|
| 374 | case "p":
|
---|
| 375 | $bezart="hat";
|
---|
| 376 | break;
|
---|
| 377 | case "m":
|
---|
[41] | 378 | $bezart="zeigtAuf";
|
---|
| 379 | break;
|
---|
| 380 | }
|
---|
| 381 | $sql ="SELECT g.gml_id, g.gebaeudefunktion, g.description, g.name, g.lagezurerdoberflaeche, g.bauweise, g.anzahlderoberirdischengeschosse AS aog, g.grundflaeche, g.individualname, g.zustand, ";
|
---|
| 382 | $sql.="round(area(g.wkb_geometry)::numeric,2) AS flaeche, h.bauweise_beschreibung, u.bezeichner ";
|
---|
| 383 | $sql.="FROM ax_gebaeude g ";
|
---|
| 384 | $sql.="JOIN alkis_beziehungen v ON g.gml_id=v.beziehung_von ";
|
---|
[123] | 385 | $sql.="LEFT JOIN ax_gebaeude_bauweise h ON g.bauweise = h.bauweise_id ";
|
---|
[60] | 386 | $sql.="LEFT JOIN ax_gebaeude_funktion u ON g.gebaeudefunktion = u.wert ";
|
---|
[123] | 387 | $sql.="WHERE v.beziehung_zu= $1 AND v.beziehungsart= $2 ;";
|
---|
[41] | 388 | $v = array($gmlid,$bezart);
|
---|
| 389 | $res = pg_prepare("", $sql);
|
---|
[123] | 390 | $res = pg_execute("", $v);
|
---|
| 391 | if (!$res) {
|
---|
[81] | 392 | echo "<p class='err'>Fehler bei Gebaeude.</p>\n";
|
---|
[61] | 393 | if ($debug > 2) {echo "<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
|
---|
| 394 | }
|
---|
| 395 | $i=0;
|
---|
[123] | 396 | while($row = pg_fetch_array($res)) { // Only You!
|
---|
| 397 | echo "<p>";
|
---|
| 398 | if ($idanzeige) {linkgml($gkz, $row["gml_id"], "Gebäude");}
|
---|
| 399 | echo "</p>";
|
---|
[41] | 400 | echo "\n<table>";
|
---|
[123] | 401 |
|
---|
| 402 | echo "\n\t<tr><td>Funktion:</td><td>";
|
---|
| 403 | if ($showkey) {
|
---|
| 404 | echo "<span class='key'>".$row["gebaeudefunktion"]."</span> ";
|
---|
| 405 | }
|
---|
| 406 | echo $row["bezeichner"]."</td></tr>"; // integer
|
---|
| 407 |
|
---|
| 408 | if (!$row["description"] == "") {
|
---|
| 409 | echo "\n\t<tr><td>Beschreibung:</td><td>".$row["description"]."</td></tr>"; // integer - EntschlÃŒsseln!
|
---|
[64] | 410 | }
|
---|
[123] | 411 |
|
---|
[64] | 412 | if (!$row["name"] == "") {
|
---|
[123] | 413 | echo "\n\t<tr><td>Name:</td><td>".$row["name"]."</td></tr>"; // char(25)
|
---|
| 414 | }
|
---|
[64] | 415 |
|
---|
| 416 | if (!$row["lagezurerdoberflaeche"] == "") {
|
---|
[123] | 417 | echo "\n\t<tr><td>Lage zur Erdoberfläche:</td><td>".$row["lagezurerdoberflaeche"]."</td></tr>";
|
---|
| 418 | } // integer - EntschlÃŒsseln!
|
---|
[64] | 419 |
|
---|
| 420 | if (!$row["bauweise"] == "") {
|
---|
[123] | 421 | echo "\n\t<tr><td>Bauweise:</td><td>";
|
---|
| 422 | if ($showkey) {
|
---|
| 423 | echo "<span class='key'>".$row["bauweise"]."</span> ";
|
---|
| 424 | }
|
---|
| 425 | echo $row["bauweise_beschreibung"]."</td></tr>"; // integer
|
---|
| 426 | }
|
---|
| 427 |
|
---|
| 428 | if (!$row["aog"] == "") {
|
---|
| 429 | echo "\n\t<tr><td>Anz. der oberird. Geschosse:</td><td>".$row["aog"]."</td></tr>"; //
|
---|
| 430 | }
|
---|
[64] | 431 |
|
---|
| 432 | if (!$row["grundflaeche"] == "") {
|
---|
[123] | 433 | echo "\n\t<tr><td>Grundfläche:</td><td title='Buchfläche'>".$row["grundflaeche"]."</td></tr>"; // integer
|
---|
| 434 | }
|
---|
| 435 |
|
---|
[41] | 436 | echo "\n\t<tr><td>Geometrische Fläche:</td><td title='berechnete Fläche'>".$row["flaeche"]." m²</td></tr>";
|
---|
[123] | 437 |
|
---|
| 438 | if (!$row["individualname"] == "") {
|
---|
| 439 | echo "\n\t<tr><td>Individualname:</td><td>".$row["individualname"]."</td></tr>"; // char(7)
|
---|
| 440 | }
|
---|
| 441 |
|
---|
| 442 | if (!$row["zustand"] == "") {
|
---|
| 443 | echo "\n\t<tr><td>Zustand:</td><td>".$row["zustand"]."</td></tr>"; // integer
|
---|
| 444 | }
|
---|
| 445 |
|
---|
| 446 | echo "\n</table>";
|
---|
| 447 | }
|
---|
| 448 | }
|
---|
| 449 |
|
---|
| 450 | ?>
|
---|
| 451 |
|
---|
| 452 | <form action=''>
|
---|
| 453 | <div class='buttonbereich noprint'>
|
---|
| 454 | <hr>
|
---|
| 455 | <input type='button' name='back' value='<<' title='Zurück' onClick='javascript:history.back()'>
|
---|
| 456 | <input type='button' name='print' value='Druck' title='Seite Drucken' onClick='window.print()'>
|
---|
[41] | 457 | <input type='button' name='close' value='X' title='Fenster schließen' onClick='window.close()'>
|
---|
| 458 | </div>
|
---|
| 459 | </form>
|
---|
| 460 |
|
---|
| 461 | <?php footer($gmlid, $_SERVER['PHP_SELF']."?", "&ltyp=".$ltyp); ?>
|
---|
| 462 |
|
---|
| 463 | </body>
|
---|
[123] | 464 | </html>
|
---|
[41] | 465 |
|
---|