Testtool, Auswertung und Reihungstestadministration benutzen nun die neuen Reihungstestanmeldetabelle

This commit is contained in:
oesi
2016-12-20 12:38:36 +01:00
parent b99123efc6
commit 8ea63d04a6
12 changed files with 935 additions and 559 deletions
+15 -54
View File
@@ -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++;
}
+55 -5
View File
@@ -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
View File
@@ -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;
}
}
}