, * Andreas Oesterreicher and * Rudolf Hangl . */ require_once('../config.inc.php'); require_once('../../include/functions.inc.php'); require_once('../../include/studiengang.class.php'); function sortByField($multArray,$sortField,$desc=true) { $tmpKey=''; $ResArray=array(); if(!is_array($multArray)) return array(); $maIndex=array_keys($multArray); $maSize=count($multArray)-1; for($i=0; $i < $maSize ; $i++) { $minElement=$i; $tempMin=$multArray[$maIndex[$i]]->$sortField; $tmpKey=$maIndex[$i]; for($j=$i+1; $j <= $maSize; $j++) if($multArray[$maIndex[$j]]->$sortField < $tempMin ) { $minElement=$j; $tmpKey=$maIndex[$j]; $tempMin=$multArray[$maIndex[$j]]->$sortField; } $maIndex[$minElement]=$maIndex[$i]; $maIndex[$i]=$tmpKey; } if($desc) for($j=0;$j<=$maSize;$j++) $ResArray[$maIndex[$j]]=$multArray[$maIndex[$j]]; else for($j=$maSize;$j>=0;$j--) $ResArray[$maIndex[$j]]=$multArray[$maIndex[$j]]; return $ResArray; } // Verbindungsaufbau if (!$conn = pg_connect(CONN_STRING)) die("Es konnte keine Verbindung zum Server aufgebaut werden."); $ergebnis=''; $kategorie=array(); $erg_kat=array(); // Reihungstests laden $sql_query="; SELECT * FROM public.tbl_reihungstest WHERE date_part('year',datum)=date_part('year',now()) ORDER BY datum,uhrzeit"; //echo $sql_query; if(!($result=pg_query($conn, $sql_query))) die(pg_errormessage($conn)); while ($row=pg_fetch_object($result)) { $rtest[$row->reihungstest_id]->reihungstest_id=$row->reihungstest_id; $rtest[$row->reihungstest_id]->studiengang_kz=$row->studiengang_kz; $rtest[$row->reihungstest_id]->ort_kurzbz=$row->ort_kurzbz; $rtest[$row->reihungstest_id]->anmerkung=$row->anmerkung; $rtest[$row->reihungstest_id]->datum=$row->datum; $rtest[$row->reihungstest_id]->uhrzeit=$row->uhrzeit; } if (isset($_POST['reihungstest'])) { // Vorkommende Gebiete laden $sql_query="SELECT DISTINCT gebiet_id, gebiet FROM testtool.vw_auswertung"; //echo $sql_query; if(!($result=pg_query($conn, $sql_query))) die(pg_errormessage($conn)); while ($row=pg_fetch_object($result)) { $gebiet[$row->gebiet_id]->name=$row->gebiet; $gebiet[$row->gebiet_id]->gebiet_id=$row->gebiet_id; } // Ergebnisse laden $sql_query="SELECT vw_auswertung.* FROM testtool.vw_auswertung"; if (isset($_POST['reihungstest'])) $sql_query.=' JOIN public.tbl_prestudent USING (prestudent_id) WHERE reihungstest_id='.$_POST['reihungstest']; if(isset($_POST['studiengang']) && $_POST['studiengang']!='') $sql_query.=" AND tbl_prestudent.studiengang_kz='".$_POST['studiengang']."'"; //echo $sql_query; if(!($result=pg_query($conn, $sql_query))) die(pg_errormessage($conn)); while ($row=pg_fetch_object($result)) { $ergebnis[$row->pruefling_id]->pruefling_id=$row->pruefling_id; $ergebnis[$row->pruefling_id]->nachname=$row->nachname; $ergebnis[$row->pruefling_id]->vorname=$row->vorname; $ergebnis[$row->pruefling_id]->gebdatum=$row->gebdatum; $ergebnis[$row->pruefling_id]->geschlecht=$row->geschlecht; $ergebnis[$row->pruefling_id]->idnachweis=$row->idnachweis; $ergebnis[$row->pruefling_id]->registriert=$row->registriert; $ergebnis[$row->pruefling_id]->stg_kurzbz=$row->stg_kurzbz; $ergebnis[$row->pruefling_id]->stg_bez=$row->stg_bez; $ergebnis[$row->pruefling_id]->gruppe=$row->gruppe_kurzbz; $ergebnis[$row->pruefling_id]->gebiet[$row->gebiet_id]->name=$row->gebiet; $ergebnis[$row->pruefling_id]->gebiet[$row->gebiet_id]->anz_fragen=$row->anz_fragen; $ergebnis[$row->pruefling_id]->gebiet[$row->gebiet_id]->abzug=$row->abzug; $ergebnis[$row->pruefling_id]->gebiet[$row->gebiet_id]->anz_richtig=$row->anz_richtig; $ergebnis[$row->pruefling_id]->gebiet[$row->gebiet_id]->anz_antworten=$row->anz_antworten; $ergebnis[$row->pruefling_id]->gebiet[$row->gebiet_id]->anz_falsch=$row->anz_falsch; $ergebnis[$row->pruefling_id]->gebiet[$row->gebiet_id]->punkte=$row->punkte; $ergebnis[$row->pruefling_id]->gebiet[$row->gebiet_id]->prozent=$row->prozent; if (isset($ergebnis[$row->pruefling_id]->gesamt)) $ergebnis[$row->pruefling_id]->gesamt+=$row->prozent; else $ergebnis[$row->pruefling_id]->gesamt=$row->prozent; } $ergb=sortByField($ergebnis,'gesamt'); // Vorkommende Kategorien laden $sql_query="SELECT DISTINCT kategorie_kurzbz FROM testtool.vw_auswertung_kategorie"; if (isset($_POST['reihungstest'])) $sql_query.=' JOIN public.tbl_prestudent USING (prestudent_id) WHERE reihungstest_id='.$_POST['reihungstest']; if(isset($_POST['studiengang']) && $_POST['studiengang']!='') $sql_query.=" AND tbl_prestudent.studiengang_kz='".$_POST['studiengang']."'"; //echo $sql_query; if(!($result=pg_query($conn, $sql_query))) die(pg_errormessage($conn)); while ($row=pg_fetch_object($result)) $kategorie[$row->kategorie_kurzbz]->name=$row->kategorie_kurzbz; // Ergebnisse laden $sql_query="SELECT vw_auswertung_kategorie.*, tbl_kriterien.typ FROM (testtool.vw_auswertung_kategorie JOIN testtool.tbl_kriterien USING (kategorie_kurzbz))"; if (isset($_POST['reihungstest'])) $sql_query.=' JOIN public.tbl_prestudent USING (prestudent_id)'; $sql_query.=" WHERE vw_auswertung_kategorie.gebiet_id=tbl_kriterien.gebiet_id AND tbl_kriterien.punkte=vw_auswertung_kategorie.richtig"; if (isset($_POST['reihungstest'])) $sql_query.=' AND reihungstest_id='.$_POST['reihungstest']; if(isset($_POST['studiengang']) && $_POST['studiengang']!='') $sql_query.=" AND tbl_prestudent.studiengang_kz='".$_POST['studiengang']."'"; $sql_query.=" ORDER BY pruefling_id, kategorie_kurzbz"; //echo $sql_query; if(!($result=pg_query($conn, $sql_query))) die(pg_errormessage($conn)); while ($row=pg_fetch_object($result)) { $erg_kat[$row->pruefling_id]->pruefling_id=$row->pruefling_id; $erg_kat[$row->pruefling_id]->nachname=$row->nachname; $erg_kat[$row->pruefling_id]->vorname=$row->vorname; $erg_kat[$row->pruefling_id]->gebdatum=$row->gebdatum; $erg_kat[$row->pruefling_id]->geschlecht=$row->geschlecht; $erg_kat[$row->pruefling_id]->idnachweis=$row->idnachweis; $erg_kat[$row->pruefling_id]->registriert=$row->registriert; $erg_kat[$row->pruefling_id]->stg_kurzbz=$row->stg_kurzbz; $erg_kat[$row->pruefling_id]->stg_bez=$row->stg_bez; $erg_kat[$row->pruefling_id]->gruppe=$row->gruppe_kurzbz; $erg_kat[$row->pruefling_id]->kategorie[$row->kategorie_kurzbz]->name=$row->kategorie_kurzbz; $erg_kat[$row->pruefling_id]->kategorie[$row->kategorie_kurzbz]->richtig=$row->richtig; $erg_kat[$row->pruefling_id]->kategorie[$row->kategorie_kurzbz]->falsch=$row->falsch; $erg_kat[$row->pruefling_id]->kategorie[$row->kategorie_kurzbz]->gesamt=$row->gesamt; $erg_kat[$row->pruefling_id]->kategorie[$row->kategorie_kurzbz]->typ=$row->typ; $erg_kat[$row->pruefling_id]->kategorie[$row->kategorie_kurzbz]->punkte=$row->richtig.'/'.$row->gesamt; } } //Studiengaenge laden $stg_obj = new studiengang($conn); $stg_obj->getAll(null, false); $stg_arr = array(); foreach($stg_obj->result as $row) $stg_arr[$row->studiengang_kz]=$row->kuerzel; ?> Testtool - Auswertung

Auswertung Reihungstest

Reihungstest wählen:  Studiengang:

Technischer Teil

$gbt->name"; ?> Punkte"; ?> "; foreach ($gebiet AS $gbt) if (isset($erg->gebiet[$gbt->gebiet_id])) echo ''; else echo ''; echo ''; echo ''; } } ?>
IDNachnameVornamen GebDatumGIdNachweis RegistriertSTGStudiengang Grp Gesamt
ProzentProzentpunkte
$erg->pruefling_id$erg->nachname$erg->vorname$erg->gebdatum$erg->geschlecht $erg->idnachweis$erg->registriert$erg->stg_kurzbz$erg->stg_bez$erg->gruppe'.number_format($erg->gebiet[$gbt->gebiet_id]->punkte,2,',',' ').''.number_format($erg->gebiet[$gbt->gebiet_id]->prozent,2,',',' ').' %'.number_format($erg->gesamt,2,',',' ').'

Kategorien

$gbt->name"; ?> Punkte"; ?> "; foreach ($kategorie AS $gbt) echo ''; echo ''; } ?>
IDNachnameVornamen GebDatumGIdNachweis RegistriertSTGStudiengang Grp
Typ
$erg->pruefling_id$erg->nachname$erg->vorname$erg->gebdatum$erg->geschlecht $erg->idnachweis$erg->registriert$erg->stg_kurzbz$erg->stg_bez$erg->gruppe'.$erg->kategorie[$gbt->name]->punkte.''.$erg->kategorie[$gbt->name]->typ.'