mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 12:19:28 +00:00
637 lines
19 KiB
PHP
637 lines
19 KiB
PHP
<?php
|
|
/* Copyright (C) 2010 Technikum-Wien
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as
|
|
* published by the Free Software Foundation; either version 2 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
|
|
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at> and
|
|
* Karl Burkhart <burkhart@technikum-wien.at>.
|
|
*/
|
|
/**
|
|
* Klasse WaWi Kostenstelle
|
|
*/
|
|
require_once(dirname(__FILE__).'/basis_db.class.php');
|
|
require_once(dirname(__FILE__).'/geschaeftsjahr.class.php');
|
|
|
|
|
|
class wawi_kostenstelle extends basis_db
|
|
{
|
|
public $new; // boolean
|
|
public $result = array();
|
|
public $user;
|
|
|
|
public $kostenstelle_id; // integer, PK
|
|
public $oe_kurzbz; // string, FK
|
|
public $bezeichnung; // string
|
|
public $kurzbz; // string
|
|
public $aktiv; // boolean
|
|
public $updateamum; // timestamp
|
|
public $updatevon; // string
|
|
public $insertamum; // timestamp
|
|
public $insertvon; // string
|
|
public $ext_id; // integer
|
|
public $kostenstelle_nr; // string
|
|
public $deaktiviertamum; // timestamp
|
|
public $deaktiviertvon; // string
|
|
|
|
|
|
/**
|
|
* Konstruktor
|
|
* @param kostenstelle ID der Kostenstelle die geladen werden soll (Default=null)
|
|
*/
|
|
public function __construct($kostenstelle_id = null)
|
|
{
|
|
parent::__construct();
|
|
|
|
if(!is_null($kostenstelle_id))
|
|
$this->load($kostenstelle_id);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Lädt die Kostenstelle mit der übergebenen ID
|
|
* @param $kostenstelle_id der Kostenstelle die geladen werden soll
|
|
* @return true wenn ok, false wenn fehler aufgetreten sind oder kein Eintrag mit der ID gefunden wurde
|
|
*/
|
|
public function load($kostenstelle_id)
|
|
{
|
|
// pruefen ob die übergebene id eine eine gültige zahl ist
|
|
if(!is_numeric($kostenstelle_id) || ($kostenstelle_id ==''))
|
|
{
|
|
$this->errormsg = 'Kostenstellen ID ist keine Zahl';
|
|
return false;
|
|
}
|
|
|
|
$qry = 'SELECT * FROM wawi.tbl_kostenstelle WHERE kostenstelle_id='.$this->db_add_param($kostenstelle_id, FHC_INTEGER).';';
|
|
|
|
if(!$this->db_query($qry))
|
|
{
|
|
$this->errormsg = 'Fehler bei einer Datenbankabfrage';
|
|
return false;
|
|
}
|
|
|
|
if($row = $this->db_fetch_object())
|
|
{
|
|
$this->kostenstelle_id = $row->kostenstelle_id;
|
|
$this->oe_kurzbz = $row->oe_kurzbz;
|
|
$this->bezeichnung = $row->bezeichnung;
|
|
$this->kurzbz = $row->kurzbz;
|
|
$this->aktiv = $this->db_parse_bool($row->aktiv);
|
|
$this->updateamum = $row->updateamum;
|
|
$this->updatevon = $row->updatevon;
|
|
$this->insertamum = $row->insertamum;
|
|
$this->insertvon = $row->insertvon;
|
|
$this->ext_id = $row->ext_id;
|
|
$this->kostenstelle_nr = $row->kostenstelle_nr;
|
|
$this->deaktiviertamum = $row->deaktiviertamum;
|
|
$this->deaktiviertvon = $row->deaktiviertvon;
|
|
}
|
|
else
|
|
{
|
|
$this->errormsg = 'Es ist kein Datensatz mit dieser ID vorhanden';
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Gibt alle Kostenstellen zurück
|
|
*/
|
|
public function getAll($filter ='')
|
|
{
|
|
$qry = 'SELECT * FROM wawi.tbl_kostenstelle';
|
|
|
|
if($filter != '')
|
|
{
|
|
$qry.=" WHERE lower(oe_kurzbz) LIKE lower('%".$this->db_escape($filter)."%') OR
|
|
lower(bezeichnung) LIKE lower('%".$this->db_escape($filter)."%') OR
|
|
lower(kurzbz) LIKE lower('%".$this->db_escape($filter)."%')";
|
|
}
|
|
|
|
$qry.=' ORDER BY bezeichnung;';
|
|
|
|
if(!$this->db_query($qry))
|
|
{
|
|
$this->errormsg = 'Fehler bei der Datenbankabfrage.';
|
|
return false;
|
|
}
|
|
|
|
while($row = $this->db_fetch_object())
|
|
{
|
|
$obj = new wawi_kostenstelle();
|
|
|
|
$obj->kostenstelle_id = $row->kostenstelle_id;
|
|
$obj->oe_kurzbz = $row->oe_kurzbz;
|
|
$obj->bezeichnung = $row->bezeichnung;
|
|
$obj->kurzbz = $row->kurzbz;
|
|
$obj->aktiv = $this->db_parse_bool($row->aktiv);
|
|
$obj->updateamum = $row->updateamum;
|
|
$obj->updatevon = $row->updatevon;
|
|
$obj->insertamum = $row->insertamum;
|
|
$obj->insertvon = $row->insertvon;
|
|
$obj->ext_id = $row->ext_id;
|
|
$obj->kostenstelle_nr = $row->kostenstelle_nr;
|
|
$obj->deaktiviertamum = $row->deaktiviertamum;
|
|
$obj->deaktiviertvon = $row->deaktiviertvon;
|
|
|
|
$this->result[] = $obj;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Löscht die Kostenstelle mit der übergebenen ID
|
|
* @param $kostenstelle_id, id des Datensatzes der gelöscht wird
|
|
* @return true wenn OK, false wenn ein Fehler aufgetreten ist
|
|
*/
|
|
public function delete($kostenstelle_id)
|
|
{
|
|
if(!is_numeric($kostenstelle_id) || $kostenstelle_id =='')
|
|
{
|
|
$this->errormsg = 'Ungültige Kostenstellen ID';
|
|
return false;
|
|
}
|
|
$qry ="SELECT * FROM wawi.tbl_bestellung WHERE kostenstelle_id = ".$this->db_add_param($kostenstelle_id, FHC_INTEGER, false).';';
|
|
if(!$this->db_query($qry))
|
|
{
|
|
$this->errormsg = 'Fehler beim Löschen des Datensatzes';
|
|
return false;
|
|
}
|
|
if($row = $this->db_fetch_object())
|
|
{
|
|
$this->errormsg = "Kostenstelle kann nicht gelöscht werden. Diese Kostenstelle verweist noch auf eine Bestelltung.";
|
|
return false;
|
|
}
|
|
|
|
$qry = "DELETE FROM wawi.tbl_konto_kostenstelle WHERE kostenstelle_id =".$this->db_add_param($kostenstelle_id, FHC_INTEGER, false)."; ";
|
|
$qry .= "DELETE FROM wawi.tbl_aufteilung_default WHERE kostenstelle_id =".$this->db_add_param($kostenstelle_id, FHC_INTEGER, false)."; ";
|
|
$qry .= "DELETE FROM system.tbl_benutzerrolle WHERE kostenstelle_id =".$this->db_add_param($kostenstelle_id, FHC_INTEGER, false)."; ";
|
|
$qry .= "DELETE FROM wawi.tbl_kostenstelle WHERE kostenstelle_id=".$this->db_add_param($kostenstelle_id, FHC_INTEGER, false).";";
|
|
|
|
if(!$this->db_query($qry))
|
|
{
|
|
$this->errormsg = 'Fehler beim Löschen des Datensatzes';
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Prueft die Variablen auf Gueltigkeit
|
|
* @return true wenn ok, false im Fehlerfall
|
|
*/
|
|
protected function validate()
|
|
{
|
|
if(mb_strlen($this->kostenstelle_nr)>4)
|
|
{
|
|
$this->errormsg = 'Kostenstellennummer darf nicht laenger als 4 Zeichen sein.';
|
|
}
|
|
|
|
if(mb_strlen($this->bezeichnung)>256)
|
|
{
|
|
$this->errormsg = 'Bezeichnung darf nicht laenger als 256 Zeichen sein.';
|
|
return false;
|
|
}
|
|
|
|
if(mb_strlen($this->kurzbz)>32)
|
|
{
|
|
$this->errormsg = 'Kurzbezeichnung darf nicht laenger als 32 Zeichen sein.';
|
|
return false;
|
|
}
|
|
|
|
$this->errormsg = '';
|
|
return true;
|
|
}
|
|
|
|
|
|
/**
|
|
* Speichert den aktuellen Datensatz in die Datenbank
|
|
* Wenn $neu auf true gesetzt ist wird ein neuer Datensatz angelegt
|
|
* andernfalls wird der Datensatz mit der ID in $kostenstelle_id aktualisiert
|
|
* @param $new wenn true wird ein Insert durchgefuehrt, wenn false ein Update
|
|
* und wenn null wird das new-Objekt der Klasse verwendet
|
|
* @return true wenn ok, false im Fehlerfall
|
|
*/
|
|
public function save($new=null)
|
|
{
|
|
if(is_null($new))
|
|
$new = $this->new;
|
|
|
|
//Variablen pruefen
|
|
if(!$this->validate())
|
|
return false;
|
|
|
|
|
|
if($this->new)
|
|
{
|
|
//Neuen Datensatz einfuegen
|
|
$qry='BEGIN;INSERT INTO wawi.tbl_kostenstelle (oe_kurzbz, bezeichnung, kurzbz, aktiv, updateamum, updatevon,
|
|
insertamum, insertvon, kostenstelle_nr, deaktiviertamum, deaktiviertvon ) VALUES('.
|
|
$this->db_add_param($this->oe_kurzbz).', '.
|
|
$this->db_add_param($this->bezeichnung).', '.
|
|
$this->db_add_param($this->kurzbz).', '.
|
|
$this->db_add_param($this->aktiv, FHC_BOOLEAN).', '.
|
|
$this->db_add_param($this->updateamum).', '.
|
|
$this->db_add_param($this->updatevon).', '.
|
|
$this->db_add_param($this->insertamum).', '.
|
|
$this->db_add_param($this->insertvon).', '.
|
|
$this->db_add_param($this->kostenstelle_nr).', '.
|
|
$this->db_add_param($this->deaktiviertamum).', '.
|
|
$this->db_add_param($this->deaktiviertvon).');';
|
|
|
|
}
|
|
else
|
|
{
|
|
//Pruefen ob kostenstelle_id eine gueltige Zahl ist
|
|
if(!is_numeric($this->kostenstelle_id))
|
|
{
|
|
$this->errormsg = 'kostenstelle_id muss eine gültige Zahl sein';
|
|
return false;
|
|
}
|
|
$qry='UPDATE wawi.tbl_kostenstelle SET'.
|
|
' oe_kurzbz='.$this->db_add_param($this->oe_kurzbz).', '.
|
|
' bezeichnung='.$this->db_add_param($this->bezeichnung).', '.
|
|
' kurzbz='.$this->db_add_param($this->kurzbz).', '.
|
|
' aktiv='.$this->db_add_param($this->aktiv, FHC_BOOLEAN).', '.
|
|
' updateamum='.$this->db_add_param($this->updateamum).', '.
|
|
' updatevon='.$this->db_add_param($this->updatevon).', '.
|
|
' insertamum='.$this->db_add_param($this->insertamum).', '.
|
|
' insertvon='.$this->db_add_param($this->insertvon).', '.
|
|
' kostenstelle_nr='.$this->db_add_param($this->kostenstelle_nr).', '.
|
|
' deaktiviertamum='.$this->db_add_param($this->deaktiviertamum).', '.
|
|
' deaktiviertvon='.$this->db_add_param($this->deaktiviertvon).' '.
|
|
' WHERE kostenstelle_id='.$this->db_add_param($this->kostenstelle_id, FHC_INTEGER, false).';';
|
|
}
|
|
|
|
if($this->db_query($qry))
|
|
{
|
|
if($this->new)
|
|
{
|
|
//naechste ID aus der Sequence holen
|
|
$qry="SELECT currval('wawi.seq_kostenstelle_kostenstelle_id') as id;";
|
|
if($this->db_query($qry))
|
|
{
|
|
if($row = $this->db_fetch_object())
|
|
{
|
|
$this->kostenstelle_id = $row->id;
|
|
$this->db_query('COMMIT');
|
|
}
|
|
else
|
|
{
|
|
$this->db_query('ROLLBACK');
|
|
$this->errormsg = "Fehler beim Auslesen der Sequence";
|
|
return false;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$this->db_query('ROLLBACK');
|
|
$this->errormsg = 'Fehler beim Auslesen der Sequence';
|
|
return false;
|
|
}
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
return $this->kostenstelle_id;
|
|
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Loescht kostenstelle mit der id1 und legt dessen Schlüssel in anderen
|
|
* Tabellen auf die kostenstelle mit der id2 um
|
|
* @param $id1 kostenstelle_id des radiobuttons
|
|
* @param $id2 kostenstelle_id des radiobuttons
|
|
* @return true wenn ok, false im Fehlerfall
|
|
*/
|
|
public function zusammenlegen($id1, $id2)
|
|
{
|
|
|
|
$sql_query_upd1="BEGIN;";
|
|
$sql_query_upd1.="UPDATE wawi.tbl_aufteilung_default SET kostenstelle_id=".$this->db_add_param($id2, FHC_INTEGER)." WHERE kostenstelle_id=".$this->db_add_param($id1, FHC_INTEGER)."; ";
|
|
$sql_query_upd1.="UPDATE wawi.tbl_konto_kostenstelle SET kostenstelle_id=".$this->db_add_param($id2, FHC_INTEGER)." WHERE kostenstelle_id=".$this->db_add_param($id1, FHC_INTEGER)." AND konto_id NOT IN(SELECT konto_id FROM wawi.tbl_konto_kostenstelle WHERE kostenstelle_id=".$this->db_add_param($id2, FHC_INTEGER)."); ";
|
|
$sql_query_upd1.="DELETE FROM wawi.tbl_konto_kostenstelle WHERE kostenstelle_id=".$this->db_add_param($id1, FHC_INTEGER).";";
|
|
$sql_query_upd1.="DELETE FROM wawi.tbl_budget WHERE kostenstelle_id=".$this->db_add_param($id1, FHC_INTEGER).";";
|
|
$sql_query_upd1.="UPDATE wawi.tbl_bestellung SET kostenstelle_id=".$this->db_add_param($id2, FHC_INTEGER)." WHERE kostenstelle_id=".$this->db_add_param($id1, FHC_INTEGER)."; ";
|
|
$sql_query_upd1.="UPDATE system.tbl_benutzerrolle SET kostenstelle_id=".$this->db_add_param($id2, FHC_INTEGER)." WHERE kostenstelle_id=".$this->db_add_param($id1, FHC_INTEGER)."; ";
|
|
|
|
$sql_query_upd1.="DELETE FROM wawi.tbl_kostenstelle WHERE kostenstelle_id=".$this->db_add_param($id1, FHC_INTEGER).";";
|
|
|
|
if($this->db_query($sql_query_upd1))
|
|
{
|
|
$this->db_query("COMMIT;");
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
$this->db_query("ROLLBACK;");
|
|
$this->errormsg = "Fehler beim Update aufgetreten";
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Es wird überprüft ob der Eintrag mit den 2 IDs schon in der Zwischentabelle vorhanden ist
|
|
* @param $konto_id
|
|
* @param $kostenselle_id
|
|
* @return true wenn es Eintrag schon gibt, false wenn der Eintrag noch nicht vorhanden ist
|
|
*/
|
|
public function check_konto_kostenstelle($kostenstelle_id, $konto_id)
|
|
{
|
|
if(!is_numeric($kostenstelle_id) || $kostenstelle_id =='')
|
|
{
|
|
$this->errormsg = "Ungültige Kostenstellen ID";
|
|
return false;
|
|
}
|
|
|
|
if(!is_numeric($konto_id) || $konto_id =='')
|
|
{
|
|
$this->errormsg = "Ungültige ID";
|
|
return false;
|
|
}
|
|
|
|
$qry = "SELECT * FROM wawi.tbl_konto_kostenstelle WHERE konto_id = ".$this->db_add_param($konto_id, FHC_INTEGER)." AND kostenstelle_id = ".$this->db_add_param($kostenstelle_id, FHC_INTEGER).";";
|
|
|
|
if($this->db_query($qry))
|
|
{
|
|
if($row = $this->db_fetch_object())
|
|
return true;
|
|
else
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
$this->errormsg = 'Fehler bei Abfrage der Zwischentabelle.';
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Es wird ein neuer Eintrag in der Zwischentabelle erstellt
|
|
* @param $kostenstelle_id
|
|
* @param $konto_id
|
|
* @return true bei erfolgreichem einfügen, false wenn ein Fehler aufgetreten ist
|
|
*/
|
|
public function save_konto_kostenstelle($kostenstelle_id, $konto_id)
|
|
{
|
|
if(!is_numeric($kostenstelle_id) || $kostenstelle_id =='')
|
|
{
|
|
$this->errormsg = "Ungültige Kostenstellen ID";
|
|
return false;
|
|
}
|
|
|
|
if(!is_numeric($konto_id) || $konto_id =='')
|
|
{
|
|
$this->errormsg = "Ungültige Konto ID";
|
|
return false;
|
|
}
|
|
|
|
$qry = "INSERT INTO wawi.tbl_konto_kostenstelle (konto_id, kostenstelle_id) VALUES (".
|
|
$this->db_add_param($konto_id, FHC_INTEGER).",".
|
|
$this->db_add_param($kostenstelle_id, FHC_INTEGER).");";
|
|
|
|
if($this->db_query($qry))
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
$this->errormsg = 'Fehler bei Insert in die Zwischentabelle';
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Gibt alle Konten zurück die einer Kostenstelle zugeordnet sind
|
|
* @param $kostenstelle_id, id der Kostenstelle deren Konten zurückgeben werden sollen
|
|
* @return $konto Array aller Konten
|
|
*/
|
|
public function get_konto_from_kostenstelle($kostenstelle_id)
|
|
{
|
|
if(!is_numeric($kostenstelle_id) || $kostenstelle_id =='')
|
|
{
|
|
$this->errormsg = "Ungültige Kostenstellen ID";
|
|
return false;
|
|
}
|
|
|
|
$konto = array();
|
|
$qry = "SELECT konto_id FROM wawi.tbl_konto_kostenstelle
|
|
WHERE kostenstelle_id = ".$this->db_add_param($kostenstelle_id, FHC_INTEGER).";";
|
|
|
|
if($this->db_query($qry))
|
|
{
|
|
|
|
while($row = $this->db_fetch_object())
|
|
{
|
|
$konto[] = $row->konto_id;
|
|
}
|
|
|
|
return $konto;
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Löscht alle zugewiesenen Konten einer Kostenstelle, ausser die die übergeben wurden
|
|
* @param $kostenstelle_id, id der Kostenstelle deren zugewiesenen Konten gelöscht werden sollen
|
|
* @param Array $active, deren Konten die nicht gelöscht werden
|
|
* @return true bei erfolg, false bei Fehlerfall
|
|
*/
|
|
public function delete_konto_kostenstelle($kostenstelle_id, $active)
|
|
{
|
|
if(!is_numeric($kostenstelle_id) || $kostenstelle_id =='')
|
|
{
|
|
$this->errormsg = "Ungültige Kostenstellen ID";
|
|
return false;
|
|
}
|
|
$var = $this->implode4SQL($active);
|
|
$qry = "DELETE FROM wawi.tbl_konto_kostenstelle
|
|
WHERE kostenstelle_id = ".$this->db_add_param($kostenstelle_id)."
|
|
AND konto_ID NOT IN (".$var.") ;";
|
|
|
|
if($this->db_query($qry))
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
$this->errormsg = 'Fehler beim Löschen aus der Zwischentabelle aufgetreten.';
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Liefert das Budget einer Kostenstelle in einem Geschaeftsjahr
|
|
*
|
|
* @param $kostenstelle_id ID der Kostenstelle
|
|
* @param $geschaeftsjahr_kurzbz Geschaeftsjahr, wenn keines Uebergeben wird, wird das aktuelle genommen
|
|
*/
|
|
public function getBudget($kostenstelle_id, $geschaeftsjahr_kurzbz=null)
|
|
{
|
|
if(is_null($geschaeftsjahr_kurzbz))
|
|
{
|
|
$gj = new geschaeftsjahr();
|
|
$geschaeftsjahr_kurzbz = $gj->getAkt();
|
|
}
|
|
|
|
$qry = "SELECT budget FROM wawi.tbl_budget
|
|
WHERE kostenstelle_id=".$this->db_add_param($kostenstelle_id, FHC_INTEGER)."
|
|
AND geschaeftsjahr_kurzbz=".$this->db_add_param($geschaeftsjahr_kurzbz).";";
|
|
|
|
if($result = $this->db_query($qry))
|
|
{
|
|
if($row = $this->db_fetch_object($result))
|
|
{
|
|
return $row->budget;
|
|
}
|
|
else
|
|
{
|
|
$this->errormsg = 'Es gibt kein Budget für diese Kostenstelle';
|
|
return false;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$this->errormsg = 'Fehler beim Laden des Budgets';
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Speichert das Budget einer Kostenstelle
|
|
*
|
|
* @param $kostenstelle_id
|
|
* @param $geschaeftsjahr_kurzbz
|
|
* @param $budget
|
|
*/
|
|
public function setBudget($kostenstelle_id, $geschaeftsjahr_kurzbz, $budget)
|
|
{
|
|
if($kostenstelle_id=='')
|
|
{
|
|
$this->errormsg = 'KostenstelleID muss uebergeben weden';
|
|
return false;
|
|
}
|
|
if($geschaeftsjahr_kurzbz=='')
|
|
{
|
|
$this->errormsg = 'Geschaeftsjahr muss uebergeben werden';
|
|
return false;
|
|
}
|
|
if($budget=='')
|
|
$budget='0';
|
|
|
|
if(!is_numeric($budget))
|
|
{
|
|
$this->errormsg = 'Budget ist ungueltig';
|
|
return false;
|
|
}
|
|
|
|
$qry = '';
|
|
if($old_budget = $this->getBudget($kostenstelle_id, $geschaeftsjahr_kurzbz))
|
|
{
|
|
if($old_budget!=$budget)
|
|
{
|
|
$qry = "UPDATE
|
|
wawi.tbl_budget SET budget=".$this->db_add_param($budget)."
|
|
WHERE
|
|
kostenstelle_id=".$this->db_add_param($kostenstelle_id, FHC_INTEGER)."
|
|
AND geschaeftsjahr_kurzbz=".$this->db_add_param($geschaeftsjahr_kurzbz).";";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$qry = "INSERT INTO wawi.tbl_budget(kostenstelle_id, geschaeftsjahr_kurzbz, budget) VALUES(".
|
|
$this->db_add_param($kostenstelle_id, FHC_INTEGER).",".
|
|
$this->db_add_param($geschaeftsjahr_kurzbz).",".
|
|
$this->db_add_param($budget).");";
|
|
}
|
|
|
|
if($qry!='')
|
|
{
|
|
if($this->db_query($qry))
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
$this->errormsg='Fehler beim Speichern des Budgets';
|
|
return false;
|
|
}
|
|
}
|
|
else
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Laedt die Kostenstellen die als Array uebergeben werden
|
|
* @param $kst_id Array mit den kst_ids
|
|
* @param $order Sortierreihenfolge
|
|
* @param $aktiv wenn true dann nur aktive sonst alle
|
|
* @return true wenn ok, false im Fehlerfall
|
|
*/
|
|
public function loadArray($kst_id, $order=null, $aktiv=true)
|
|
{
|
|
if(count($kst_id)==0)
|
|
return true;
|
|
|
|
$kst_id = $this->implode4SQL($kst_id);
|
|
|
|
$qry = 'SELECT * FROM wawi.tbl_kostenstelle WHERE kostenstelle_id in('.$kst_id.')';
|
|
if ($aktiv)
|
|
$qry.=' AND aktiv=true';
|
|
|
|
if($order!=null)
|
|
$qry .=" ORDER BY $order";
|
|
|
|
if(!$result = $this->db_query($qry))
|
|
{
|
|
$this->errormsg = 'Datensatz konnte nicht geladen werden';
|
|
return false;
|
|
}
|
|
|
|
while($row = $this->db_fetch_object($result))
|
|
{
|
|
$obj = new wawi_kostenstelle();
|
|
|
|
$obj->kostenstelle_id = $row->kostenstelle_id;
|
|
$obj->oe_kurzbz = $row->oe_kurzbz;
|
|
$obj->bezeichnung = $row->bezeichnung;
|
|
$obj->kurzbz = $row->kurzbz;
|
|
$obj->aktiv = $this->db_parse_bool($row->aktiv);
|
|
$obj->updateamum = $row->updateamum;
|
|
$obj->updatevon = $row->updatevon;
|
|
$obj->insertamum = $row->insertamum;
|
|
$obj->insertvon = $row->insertvon;
|
|
$obj->ext_id = $row->ext_id;
|
|
$obj->kostenstelle_nr = $row->kostenstelle_nr;
|
|
$obj->deaktiviertvon = $row->deaktiviertvon;
|
|
$obj->deaktiviertvon = $row->deaktiviertvon;
|
|
|
|
$this->result[] = $obj;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|