mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 20:29:29 +00:00
Testtool, Auswertung und Reihungstestadministration benutzen nun die neuen Reihungstestanmeldetabelle
This commit is contained in:
@@ -357,23 +357,28 @@ class prestudent extends person
|
||||
|
||||
/**
|
||||
* Laden aller Prestudenten, die an $datum zum Reihungstest geladen sind.
|
||||
* Wenn $equal auf true gesetzt ist wird genau dieses Datum verwendet,
|
||||
* ansonsten werden auch alle mit späterem Datum geladen. ---> von kindlm am 30.03.2012 geändert
|
||||
* da zukünftige Teilnehmer nicht mehr angezeigt werden sollen.
|
||||
* @param date $datum Datum an dem der Reihungstest stattfindet
|
||||
* @return true wenn erfolgreich, false im Fehlerfall
|
||||
*/
|
||||
public function getPrestudentRT($datum, $equal=false)
|
||||
public function getPrestudentRT($datum)
|
||||
{
|
||||
$sql_query='SELECT DISTINCT * FROM public.vw_prestudent WHERE rt_datum';
|
||||
if ($equal)
|
||||
$sql_query.='=';
|
||||
else
|
||||
$sql_query.='=';
|
||||
$sql_query.="'$datum' ORDER BY nachname,vorname";
|
||||
$sql_query='SELECT
|
||||
DISTINCT tbl_prestudent.prestudent_id,
|
||||
tbl_person.vorname, tbl_person.nachname, tbl_person.person_id, tbl_person.titelpre,
|
||||
tbl_person.titelpost, tbl_person.gebdatum,tbl_prestudent.studiengang_kz,
|
||||
tbl_reihungstest.*
|
||||
FROM
|
||||
public.tbl_prestudent
|
||||
JOIN public.tbl_person USING(person_id)
|
||||
JOIN public.tbl_rt_person USING(person_id)
|
||||
JOIN public.tbl_reihungstest ON(tbl_reihungstest.reihungstest_id=tbl_rt_person.rt_id)
|
||||
WHERE tbl_reihungstest.datum='.$this->db_add_param($datum).'
|
||||
ORDER BY nachname,vorname';
|
||||
|
||||
if(!$this->db_query($sql_query))
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Speichern des Benutzer-Datensatzes:'.$sql_query;
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -385,56 +390,12 @@ class prestudent extends person
|
||||
$ps->prestudent_id = $row->prestudent_id;
|
||||
$ps->person_id = $row->person_id;
|
||||
$ps->reihungstest_id = $row->reihungstest_id;
|
||||
$ps->staatsbuergerschaft = $row->staatsbuergerschaft;
|
||||
$ps->geburtsnation = $row->geburtsnation;
|
||||
$ps->sprache = $row->sprache;
|
||||
$ps->anrede = $row->anrede;
|
||||
$ps->titelpost = $row->titelpost;
|
||||
$ps->titelpre = $row->titelpre;
|
||||
$ps->nachname = $row->nachname;
|
||||
$ps->vorname = $row->vorname;
|
||||
$ps->vornamen = $row->vornamen;
|
||||
$ps->gebdatum = $row->gebdatum;
|
||||
$ps->gebort = $row->gebort;
|
||||
$ps->gebzeit = $row->gebzeit;
|
||||
// $ps->foto = $row->foto;
|
||||
$ps->anmerkungen = $row->anmerkungen;
|
||||
$ps->homepage = $row->homepage;
|
||||
$ps->svnr = $row->svnr;
|
||||
$ps->ersatzkennzeichen = $row->ersatzkennzeichen;
|
||||
$ps->familienstand = $row->familienstand;
|
||||
$ps->geschlecht = $row->geschlecht;
|
||||
$ps->anzahlkinder = $row->anzahlkinder;
|
||||
$ps->aktiv = $this->db_parse_bool($row->aktiv);
|
||||
$ps->aufmerksamdurch_kurzbz = $row->aufmerksamdurch_kurzbz;
|
||||
$ps->studiengang_kz = $row->studiengang_kz;
|
||||
$ps->berufstaetigkeit_code = $row->berufstaetigkeit_code;
|
||||
$ps->ausbildungcode = $row->ausbildungcode;
|
||||
$ps->zgv_code = $row->zgv_code;
|
||||
$ps->zgvort = $row->zgvort;
|
||||
$ps->zgvdatum = $row->zgvdatum;
|
||||
//$ps->zgvnation = $row->zgvnation;
|
||||
$ps->zgvmas_code = $row->zgvmas_code;
|
||||
$ps->zgvmaort = $row->zgvmaort;
|
||||
$ps->zgvmadatum = $row->zgvmadatum;
|
||||
//$ps->zgvmanation = $row->zgvmanation;
|
||||
$ps->aufnahmeschluessel = $row->aufnahmeschluessel;
|
||||
$ps->facheinschlberuf = $this->db_parse_bool($row->facheinschlberuf);
|
||||
$ps->anmeldungreihungstest = $row->anmeldungreihungstest;
|
||||
$ps->reihungstestangetreten = $this->db_parse_bool($row->reihungstestangetreten);
|
||||
$ps->punkte = $row->punkte;
|
||||
$ps->rt_punkte1 = $row->rt_punkte1;
|
||||
$ps->rt_punkte2 = $row->rt_punkte2;
|
||||
$ps->bismelden = $this->db_parse_bool($row->bismelden);
|
||||
$ps->rt_studiengang_kz = $row->rt_studiengang_kz;
|
||||
$ps->rt_ort = $row->rt_ort;
|
||||
$ps->rt_datum = $row->rt_datum;
|
||||
$ps->rt_uhrzeit = $row->rt_uhrzeit;
|
||||
$ps->updateamum = $row->updateamum;
|
||||
$ps->updatevon = $row->updatevon;
|
||||
$ps->insertamum = $row->insertamum;
|
||||
$ps->insertvon = $row->insertvon;
|
||||
//$ps->ext_id_prestudent = $row->ext_id_prestudent;
|
||||
$this->result[]=$ps;
|
||||
$this->num_rows++;
|
||||
}
|
||||
|
||||
@@ -307,15 +307,20 @@ class pruefling extends basis_db
|
||||
}
|
||||
|
||||
/**
|
||||
* Berechnet das Reihungstestergebnis fuer einen Prestudenten
|
||||
* Berechnet das Reihungstestergebnis fuer eine Person und ggf Reihungstest
|
||||
*
|
||||
* @param $prestudent_id
|
||||
* @param $person_id ID der Person.
|
||||
* @param $punkte Wenn true werden Punkte geliefert, sonst Prozentsumme.
|
||||
* @param $reihungstest_id ID des Reihungstests.
|
||||
* @return Endpunkte des Reihungstests
|
||||
*/
|
||||
public function getReihungstestErgebnis($prestudent_id, $punkte=false)
|
||||
public function getReihungstestErgebnisPerson($person_id, $punkte=false, $reihungstest_id=null)
|
||||
{
|
||||
$qry = "SELECT * FROM testtool.vw_auswertung
|
||||
WHERE prestudent_id=".$this->db_add_param($prestudent_id, FHC_INTEGER);
|
||||
WHERE person_id=".$this->db_add_param($person_id, FHC_INTEGER);
|
||||
|
||||
if(!is_null($reihungstest_id))
|
||||
$qry.=" AND reihungstest_id=".$this->db_add_param($reihungstest_id, FHC_INTEGER);
|
||||
|
||||
$ergebnis=0;
|
||||
|
||||
@@ -335,7 +340,52 @@ class pruefling extends basis_db
|
||||
if($punkte)
|
||||
$ergebnis +=$row->punkte;
|
||||
else
|
||||
$ergebnis+=$prozent*$row->gewicht;
|
||||
$ergebnis+=$prozent*$row->gewicht;
|
||||
}
|
||||
return $ergebnis;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler bei einer Abfrage';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Berechnet das Reihungstestergebnis fuer einen Prestudenten und ggf Reihungstest
|
||||
*
|
||||
* @param $prestudent_id ID des Prestudenten
|
||||
* @param $punkte Wenn true werden Punkte geliefert, sonst Prozentsumme.
|
||||
* @param $reihungstest_id ID des Reihungstests.
|
||||
* @return Endpunkte des Reihungstests
|
||||
*/
|
||||
public function getReihungstestErgebnisPrestudent($prestudent_id, $punkte=false, $reihungstest_id=null)
|
||||
{
|
||||
$qry = "SELECT * FROM testtool.vw_auswertung
|
||||
WHERE prestudent_id=".$this->db_add_param($prestudent_id, FHC_INTEGER);
|
||||
|
||||
if(!is_null($reihungstest_id))
|
||||
$qry.=" AND reihungstest_id=".$this->db_add_param($reihungstest_id, FHC_INTEGER);
|
||||
|
||||
$ergebnis=0;
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
while($row = $this->db_fetch_object())
|
||||
{
|
||||
//wenn maxpunkte ueberschritten wurde -> 100%
|
||||
if($row->punkte>=$row->maxpunkte)
|
||||
{
|
||||
$prozent=100;
|
||||
$row->punkte = $row->maxpunkte;
|
||||
}
|
||||
else
|
||||
$prozent = ($row->punkte/$row->maxpunkte)*100;
|
||||
|
||||
if($punkte)
|
||||
$ergebnis +=$row->punkte;
|
||||
else
|
||||
$ergebnis+=$prozent*$row->gewicht;
|
||||
}
|
||||
return $ergebnis;
|
||||
}
|
||||
|
||||
+109
-23
@@ -28,7 +28,7 @@ require_once(dirname(__FILE__).'/basis_db.class.php');
|
||||
|
||||
class reihungstest extends basis_db
|
||||
{
|
||||
public $new; // boolean
|
||||
public $new=true; // boolean
|
||||
public $done = false; // boolean
|
||||
public $result = array();
|
||||
|
||||
@@ -476,7 +476,7 @@ class reihungstest extends basis_db
|
||||
FROM
|
||||
public.tbl_rt_person
|
||||
WHERE
|
||||
reihungstest_id = '.$this->db_add_param($reihungstest_id, FHC_INTEGER);
|
||||
rt_id = '.$this->db_add_param($reihungstest_id, FHC_INTEGER);
|
||||
|
||||
if ($result = $this->db_query($qry))
|
||||
{
|
||||
@@ -541,7 +541,7 @@ class reihungstest extends basis_db
|
||||
if ($row = $this->db_fetch_object($result))
|
||||
{
|
||||
$this->rt_person_id = $row->rt_person_id;
|
||||
$this->rt_id = $row->rt_id;
|
||||
$this->reihungstest_id = $row->rt_id;
|
||||
$this->person_id = $row->person_id;
|
||||
$this->studienplan_id = $row->studienplan_id;
|
||||
$this->anmeldedatum = $row->anmeldedatum;
|
||||
@@ -584,7 +584,7 @@ class reihungstest extends basis_db
|
||||
$obj = new stdClass();
|
||||
|
||||
$obj->rt_person_id = $row->rt_person_id;
|
||||
$obj->rt_id = $row->rt_id;
|
||||
$obj->reihungstest_id = $row->rt_id;
|
||||
$obj->person_id = $row->person_id;
|
||||
$obj->studienplan_id = $row->studienplan_id;
|
||||
$obj->anmeldedatum = $row->anmeldedatum;
|
||||
@@ -606,10 +606,10 @@ class reihungstest extends basis_db
|
||||
/**
|
||||
* Liefert die Zuordnung einer Person zu einem Reihungstest
|
||||
* @param int $person_id ID der Person.
|
||||
* @param int $rt_id ID des Reihungstests.
|
||||
* @param int $reihungstest_id ID des Reihungstests.
|
||||
* @return boolean true wenn erfolgreich, false im Fehlerfall
|
||||
*/
|
||||
public function getPersonReihungstest($person_id, $rt_id)
|
||||
public function getPersonReihungstest($person_id, $reihungstest_id)
|
||||
{
|
||||
$qry = "SELECT
|
||||
*
|
||||
@@ -617,13 +617,13 @@ class reihungstest extends basis_db
|
||||
public.tbl_rt_person
|
||||
WHERE
|
||||
tbl_rt_person.person_id=".$this->db_add_param($person_id)."
|
||||
AND rt_id=".$this->db_add_param($rt_id);
|
||||
AND rt_id=".$this->db_add_param($reihungstest_id);
|
||||
if ($result = $this->db_query($qry))
|
||||
{
|
||||
if ($row = $this->db_fetch_object($result))
|
||||
{
|
||||
$this->rt_person_id = $row->rt_person_id;
|
||||
$this->rt_id = $row->rt_id;
|
||||
$this->reihungstest_id = $row->rt_id;
|
||||
$this->person_id = $row->person_id;
|
||||
$this->studienplan_id = $row->studienplan_id;
|
||||
$this->anmeldedatum = $row->anmeldedatum;
|
||||
@@ -647,18 +647,18 @@ class reihungstest extends basis_db
|
||||
|
||||
/**
|
||||
* Liefert die Personen, die einem Ort des Reihungstests zugeteilt sind
|
||||
* @param int $rt_id ID des Reihungstests.
|
||||
* @param string $ort_kurzbz Ort des Reihungstests mit der ID $rt_id.
|
||||
* @param int $reihungstest_id ID des Reihungstests.
|
||||
* @param string $ort_kurzbz Ort des Reihungstests mit der ID $reihungstest_id.
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
public function getPersonReihungstestOrt($rt_id, $ort_kurzbz)
|
||||
public function getPersonReihungstestOrt($reihungstest_id, $ort_kurzbz)
|
||||
{
|
||||
$qry = "SELECT
|
||||
*
|
||||
FROM
|
||||
public.tbl_rt_person
|
||||
WHERE
|
||||
tbl_rt_person.rt_id=".$this->db_add_param($rt_id)."
|
||||
tbl_rt_person.rt_id=".$this->db_add_param($reihungstest_id)."
|
||||
AND tbl_rt_person.ort_kurzbz=".$this->db_add_param($ort_kurzbz);
|
||||
if ($result = $this->db_query($qry))
|
||||
{
|
||||
@@ -667,7 +667,7 @@ class reihungstest extends basis_db
|
||||
$obj = new stdClass();
|
||||
|
||||
$obj->rt_person_id = $row->rt_person_id;
|
||||
$obj->rt_id = $row->rt_id;
|
||||
$obj->reihungstest_id = $row->rt_id;
|
||||
$obj->person_id = $row->person_id;
|
||||
$obj->studienplan_id = $row->studienplan_id;
|
||||
$obj->anmeldedatum = $row->anmeldedatum;
|
||||
@@ -697,7 +697,7 @@ class reihungstest extends basis_db
|
||||
$qry = "BEGIN;INSERT INTO public.tbl_rt_person(person_id, rt_id, studienplan_id, anmeldedatum,
|
||||
teilgenommen, ort_kurzbz, punkte) VALUES(".
|
||||
$this->db_add_param($this->person_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->rt_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->reihungstest_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->studienplan_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->anmeldedatum).','.
|
||||
$this->db_add_param($this->teilgenommen, FHC_BOOLEAN).','.
|
||||
@@ -707,7 +707,7 @@ class reihungstest extends basis_db
|
||||
else
|
||||
{
|
||||
$qry = "UPDATE public.tbl_rt_person SET ".
|
||||
' rt_id = '.$this->db_add_param($this->rt_id).','.
|
||||
' rt_id = '.$this->db_add_param($this->reihungstest_id).','.
|
||||
' studienplan_id = '.$this->db_add_param($this->studienplan_id).','.
|
||||
' anmeldedatum='.$this->db_add_param($this->anmeldedatum).','.
|
||||
' teilgenommen='.$this->db_add_param($this->teilgenommen, FHC_BOOLEAN).','.
|
||||
@@ -788,13 +788,14 @@ class reihungstest extends basis_db
|
||||
tbl_rt_ort.rt_id=".$this->db_add_param($reihungstest_id)."
|
||||
ORDER BY
|
||||
ort_kurzbz";
|
||||
|
||||
if ($result = $this->db_query($qry))
|
||||
{
|
||||
while ($row = $this->db_fetch_object($result))
|
||||
{
|
||||
$obj = new stdClass();
|
||||
|
||||
$obj->rt_id = $row->rt_id;
|
||||
$obj->reihungstest_id = $row->rt_id;
|
||||
$obj->ort_kurzbz = $row->ort_kurzbz;
|
||||
$obj->uid = $row->uid;
|
||||
|
||||
@@ -820,7 +821,7 @@ class reihungstest extends basis_db
|
||||
if ($this->new)
|
||||
{
|
||||
$qry = "INSERT INTO public.tbl_rt_ort(rt_id, ort_kurzbz, uid) VALUES(".
|
||||
$this->db_add_param($this->rt_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->reihungstest_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->ort_kurzbz).','.
|
||||
$this->db_add_param($this->uid).');';
|
||||
}
|
||||
@@ -829,7 +830,7 @@ class reihungstest extends basis_db
|
||||
$qry = "UPDATE public.tbl_rt_ort SET ".
|
||||
' ort_kurzbz='.$this->db_add_param($this->ort_kurzbz).','.
|
||||
' uid='.$this->db_add_param($this->uid).' '.
|
||||
' WHERE rt_id='.$this->db_add_param($this->rt_id, FHC_INTEGER).' AND '.
|
||||
' WHERE rt_id='.$this->db_add_param($this->reihungstest_id, FHC_INTEGER).' AND '.
|
||||
' ort_kurzbz='.$this->db_add_param($this->ort_kurzbz);
|
||||
}
|
||||
|
||||
@@ -878,14 +879,14 @@ class reihungstest extends basis_db
|
||||
if ($this->new)
|
||||
{
|
||||
$qry = "INSERT INTO public.tbl_rt_studienplan(reihungstest_id, studienplan_id) VALUES(".
|
||||
$this->db_add_param($this->rt_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->reihungstest_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->studienplan_id).');';
|
||||
}
|
||||
else
|
||||
{
|
||||
$qry = "UPDATE public.tbl_rt_studienplan SET ".
|
||||
' studienplan_id='.$this->db_add_param($this->studienplan_id).' '.
|
||||
' WHERE reihungstest_id='.$this->db_add_param($this->rt_id, FHC_INTEGER).' AND '.
|
||||
' WHERE reihungstest_id='.$this->db_add_param($this->reihungstest_id, FHC_INTEGER).' AND '.
|
||||
' studienplan_id='.$this->db_add_param($this->studienplan_id);
|
||||
}
|
||||
|
||||
@@ -966,11 +967,16 @@ class reihungstest extends basis_db
|
||||
public function getReihungstestStudienplan($studienplan_arr)
|
||||
{
|
||||
$qry = "SELECT
|
||||
distinct tbl_reihungstest.*
|
||||
distinct a.*,
|
||||
(
|
||||
SELECT count(*) FROM public.tbl_rt_person
|
||||
WHERE rt_id=a.reihungstest_id
|
||||
) as angemeldete_teilnehmer
|
||||
FROM
|
||||
public.tbl_reihungstest
|
||||
public.tbl_reihungstest a
|
||||
JOIN public.tbl_rt_studienplan USING(reihungstest_id)
|
||||
WHERE studienplan_id IN(".$this->db_implode4Sql($studienplan_arr).")";
|
||||
WHERE studienplan_id IN(".$this->db_implode4Sql($studienplan_arr).")
|
||||
ORDER BY a.datum DESC";
|
||||
|
||||
if ($this->db_query($qry))
|
||||
{
|
||||
@@ -995,6 +1001,7 @@ class reihungstest extends basis_db
|
||||
$obj->studiensemester_kurzbz = $row->studiensemester_kurzbz;
|
||||
$obj->stufe = $row->stufe;
|
||||
$obj->anmeldefrist = $row->anmeldefrist;
|
||||
$obj->angemeldete_teilnehmer = $row->angemeldete_teilnehmer;
|
||||
|
||||
$this->result[] = $obj;
|
||||
}
|
||||
@@ -1063,4 +1070,83 @@ class reihungstest extends basis_db
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Laedt die Reihungstest-Zuordnungen eines Prestudenten zu einem Datum
|
||||
* @param int $prestudent_id ID des Prestudenten.
|
||||
* @param date $datum Datum an dem der Reihugnstest stattfindet.
|
||||
* @return boolean true wenn erfolgreich geladen, false im Fehlerfall
|
||||
*/
|
||||
public function getReihungstestPersonDatum($prestudent_id, $datum)
|
||||
{
|
||||
$qry = "SELECT
|
||||
tbl_rt_person.*
|
||||
FROM
|
||||
public.tbl_rt_person
|
||||
JOIN public.tbl_prestudent USING(person_id)
|
||||
JOIN public.tbl_reihungstest ON(tbl_reihungstest.reihungstest_id=tbl_rt_person.rt_id)
|
||||
WHERE
|
||||
tbl_prestudent.prestudent_id = ".$this->db_add_param($prestudent_id)."
|
||||
AND tbl_reihungstest.datum=".$this->db_add_param($datum);
|
||||
if($result = $this->db_query($qry))
|
||||
{
|
||||
while($row = $this->db_fetch_object($result))
|
||||
{
|
||||
$obj = new stdClass();
|
||||
|
||||
$obj->rt_person_id = $row->rt_person_id;
|
||||
$obj->reihungstest_id = $row->rt_id;
|
||||
$obj->person_id = $row->person_id;
|
||||
$obj->studienplan_id = $row->studienplan_id;
|
||||
$obj->anmeldedatum = $row->anmeldedatum;
|
||||
$obj->teilgenommen = $this->db_parse_bool($row->teilgenommen);
|
||||
$obj->ort_kurzbz = $row->ort_kurzbz;
|
||||
$obj->punkte = $row->punkte;
|
||||
|
||||
$this->result[] = $obj;
|
||||
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Ermittelt die Anzahl der maximalen Platzanzahl aufgrund der Raumzuordnung
|
||||
* @param int $reihungstest_id ID des Reihungstests.
|
||||
* @return Anzahl der Plaetze
|
||||
*/
|
||||
public function getPlatzAnzahlRaum($reihungstest_id)
|
||||
{
|
||||
$qry = "
|
||||
SELECT
|
||||
sum(tbl_ort.arbeitsplaetze) as anzahl
|
||||
FROM
|
||||
public.tbl_rt_ort
|
||||
JOIN public.tbl_ort USING(ort_kurzbz)
|
||||
WHERE
|
||||
tbl_rt_ort.rt_id = ".$this->db_add_param($reihungstest_id, FHC_INTEGER);
|
||||
|
||||
if($result = $this->db_query($qry))
|
||||
{
|
||||
if($row = $this->db_fetch_object($result))
|
||||
{
|
||||
return $row->anzahl;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Arbeitsplaetze';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Arbeitsplaetze';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user