, * Andreas Oesterreicher and * Rudolf Hangl . */ /** * Klasse ortraumtyp (FAS-Online) * @create 04-12-2006 */ class raumtyp { var $conn; // @var resource DB-Handle var $new; // @var boolean var $errormsg; // @var string var $result = array(); // @var fachbereich Objekt //Tabellenspalten var $beschreibung; // @var string var $raumtyp_kurzbz; // @var string /** * Konstruktor * @param $conn Connection zur DB * $ort_kurzbz und hierarchie ID des zu ladenden OrtRaumtyps */ function raumtyp($conn, $raumtyp_kurzbz=null) { $this->conn = $conn; if($raumtyp_kurzbz != null) $this->load($raumtyp_kurzbz); } /** * Laedt alle verfuegbaren OrtRaumtypen * @return true wenn ok, false im Fehlerfall */ function getAll() { $qry = 'SELECT * FROM public.tbl_raumtyp order by raumtyp_kurzbz;'; if(!$res = pg_query($this->conn, $qry)) { $this->errormsg = 'Fehler beim Laden der Datensaetze'; return false; } while($row = pg_fetch_object($res)) { $raumtyp_obj = new ort($this->conn); $raumtyp_obj->beschreibung = $row->beschreibung; $raumtyp_obj->raumtyp_kurzbz = $row->raumtyp_kurzbz; $this->result[] = $raumtyp_obj; } return true; } /** * Laedt einen Raumtyp * @param $raumtyp ID des zu ladenden Raumtyps * @return true wenn ok, false im Fehlerfall */ function load($raumtyp_kurzbz) { if($raum_kurzbz == '') { $this->errormsg = 'Kein gültiger Schlüssel vorhanden'; return false; } $qry = "SELECT * FROM public.tbl_raumtyp WHERE raumtyp_kurzbz = '$raumtyp_kurzbz';"; if(!$res = pg_query($this->conn, $qry)) { $this->errormsg = 'Fehler beim Laden des Datensatzes'; return false; } if($row=pg_fetch_object($res)) { $this->beschreibung = $row->beschreibung; $this->raumtyp_kurzbz = $row->kurzbz; } else { $this->errormsg = 'Es ist kein Datensatz mit dieser ID vorhanden'; return false; } return true; } /** * Loescht einen Datensatz * @param $raumtyp_kurzbz ID des Datensatzes der geloescht werden soll * @return true wenn ok, false im Fehlerfall */ function delete($raumtyp_kurzbz) { $this->errormsg = 'Noch nicht implementiert'; return false; } function addslashes($var) { return ($var!=''?"'".addslashes($var)."'":'null'); } /** * Prueft die Gueltigkeit der Variablen * @return true wenn ok, false im Fehlerfall */ function checkvars() { $this->beschreibung = str_replace("'",'´',$this->beschreibung); $this->raumtyp_kurzbz = str_replace("'",'´',$this->raumtyp_kurzbz); //Laenge Pruefen if(strlen($this->beschreibung)>256) { $this->errormsg = "Beschreibung darf nicht laenger als 256 Zeichen sein bei $this->raumtyp_kurzbz - ".$this->beschreibung; return false; } if(strlen($this->raumtyp_kurzbz)>8) { $this->errormsg = "Raumtyp_kurzbz darf nicht laenger als 8 Zeichen sein bei $this->raumtyp_kurzbz"; return false; } $this->errormsg = ''; return true; } /** * Speichert den aktuellen Datensatz * @return true wenn ok, false im Fehlerfall */ function save() { //Gueltigkeit der Variablen pruefen if(!$this->checkvars()) return false; if($this->new) { //Pruefen ob id gültig ist if($this->raumtyp_kurzbz == '') { $this->errormsg = 'Keine gültige ID'; return false; } //Neuen Datensatz anlegen $qry = 'INSERT INTO public.tbl_raumtyp (beschreibung, raumtyp_kurzbz) VALUES ('. $this->addslashes($this->beschreibung).', '. $this->addslashes($this->raumtyp_kurzbz).');'; } else { //bestehenden Datensatz akualisieren //Pruefen ob id gueltig ist if($this->raumtyp_kurzbz == '') { $this->errormsg = 'Keine gültige ID'; return false; } $qry = 'UPDATE public.tbl_raumtyp SET '. 'beschreibung='.$this->addslashes($this->beschreibung).' '. 'WHERE raumtyp_kurzbz = '.$this->addslashes($this->ort_kurzbz).';'; } if(pg_query($this->conn, $qry)) { /*//Log schreiben $sql = $qry; $qry = "SELECT nextval('log_seq') as id;"; if(!$row = pg_fetch_object(pg_query($this->conn, $qry))) { $this->errormsg = 'Fehler beim Auslesen der Log-Sequence'; return false; } $qry = "INSERT INTO log(log_pk, creationdate, creationuser, sql) VALUES('$row->id', now(), '$this->updatevon', '".addslashes($sql)."')"; if(pg_query($this->conn, $qry)) return true; else { $this->errormsg = 'Fehler beim Speichern des Log-Eintrages'; return false; }*/ return true; } else { $this->errormsg = 'Fehler beim Speichern des Datensatzes'; return false; } } } ?>