Files
FHC-Core/application/models/education/Zeugnisnote_model.php
T

144 lines
4.2 KiB
PHP

<?php
class Zeugnisnote_model extends DB_Model
{
/**
* Constructor
*/
public function __construct()
{
parent::__construct();
$this->dbTable = 'lehre.tbl_zeugnisnote';
$this->pk = array('studiensemester_kurzbz', 'student_uid', 'lehrveranstaltung_id');
$this->hasSequence = false;
}
/**
* Gets ECTS sums of completed courses (Zeugnisnoten) of a person for a Studiensemester.
* If no valid Noten for the course were entered, 0 ects is returned.
* @param int $person_id
* @param string $studiensemester_kurzbz
* @param bool $aktiv
* @param bool $lehre
* @param bool $offiziell
* @param bool $positiv
* @return object
*/
public function getEctsSumsByPerson($person_id, $studiensemester_kurzbz, $aktiv = true, $lehre = null, $offiziell = null, $positiv = null)
{
$params = array();
$qry = "SELECT DISTINCT ON (prst.prestudent_id) pers.matr_nr, stg.studiengang_kz, prst.prestudent_id, stg.erhalter_kz,
UPPER(stg.typ||stg.kurzbz) AS studiengang, stg.bezeichnung AS studiengang_bezeichnung, COALESCE(summen.summe_ects, 0) AS summe_ects
FROM public.tbl_person pers
JOIN public.tbl_prestudent prst USING (person_id)
JOIN public.tbl_prestudentstatus prstst USING (prestudent_id)
JOIN public.tbl_studiengang stg ON prst.studiengang_kz = stg.studiengang_kz
LEFT JOIN (
SELECT zgnisnote.student_uid, prestudent_id, zgnisnote.studiensemester_kurzbz, sum(ects) AS summe_ects
FROM public.tbl_student
LEFT JOIN lehre.tbl_zeugnisnote zgnisnote USING(student_uid)
LEFT JOIN lehre.tbl_note note ON zgnisnote.note = note.note
LEFT JOIN lehre.tbl_lehrveranstaltung lv USING (lehrveranstaltung_id)
WHERE TRUE";
if (isset($aktiv))
{
$qry .= ' AND (note.aktiv = ?)';
$params[] = $aktiv;
}
if (isset($lehre))
{
$qry .= ' AND (note.lehre = ?)';
$params[] = $lehre;
}
if (isset($offiziell))
{
$qry .= ' AND (note.offiziell = ?)';
$params[] = $offiziell;
}
if (isset($positiv))
{
$qry .= ' AND (note.positiv = ?)';
$params[] = $positiv;
}
$qry .= " GROUP BY zgnisnote.studiensemester_kurzbz, zgnisnote.student_uid, prestudent_id
) summen ON prst.prestudent_id = summen.prestudent_id AND prstst.studiensemester_kurzbz = summen.studiensemester_kurzbz
WHERE pers.person_id = ?
AND prstst.studiensemester_kurzbz = ?
ORDER BY prst.prestudent_id";
$params[] = $person_id;
$params[] = $studiensemester_kurzbz;
return $this->execQuery($qry, $params);
}
/**
* Gets courses (Zeugnisnoten) of a person for a Studiensemester.
* @param int $person_id
* @param string $studiensemester_kurzbz
* @param bool $aktiv
* @param bool $lehre
* @param bool $offiziell
* @param bool $positiv
* @param bool $zeugnis
* @return object
*/
public function getByPerson($person_id, $studiensemester_kurzbz, $aktiv = true, $lehre = null, $offiziell = null, $positiv = null, $zeugnis = null)
{
$params = array($person_id, $studiensemester_kurzbz);
$qry = "SELECT zgnisnote.*, pers.matr_nr, lv.ects, stg.studiengang_kz, prst.prestudent_id, stg.erhalter_kz,
UPPER(stg.typ||stg.kurzbz) AS studiengang, stg.bezeichnung AS studiengang_bezeichnung, note.note,
note.bezeichnung AS note_bezeichnung
FROM public.tbl_person pers
JOIN public.tbl_prestudent prst USING (person_id)
JOIN public.tbl_student USING (prestudent_id)
JOIN lehre.tbl_zeugnisnote zgnisnote USING (student_uid)
JOIN lehre.tbl_note note ON zgnisnote.note = note.note
JOIN lehre.tbl_lehrveranstaltung lv USING (lehrveranstaltung_id)
JOIN public.tbl_studiengang stg ON prst.studiengang_kz = stg.studiengang_kz
WHERE pers.person_id = ?
AND zgnisnote.studiensemester_kurzbz = ?";
if (isset($aktiv))
{
$qry .= ' AND note.aktiv = ?';
$params[] = $aktiv;
}
if (isset($lehre))
{
$qry .= ' AND note.lehre = ?';
$params[] = $lehre;
}
if (isset($offiziell))
{
$qry .= ' AND note.offiziell = ?';
$params[] = $offiziell;
}
if (isset($positiv))
{
$qry .= ' AND note.positiv = ?';
$params[] = $positiv;
}
if (isset($zeugnis))
{
$qry .= ' AND lv.zeugnis = ?';
$params[] = $zeugnis;
}
$qry .= ' ORDER BY zgnisnote.benotungsdatum';
return $this->execQuery($qry, $params);
}
}