1

我正在尝试获取特定用户在该课程所有部分的特定课程中获得的总分。

以下查询可以使用 mysql 并给出正确的结果,但不能使用 Databse API 调用

$sql = "SELECT d.section as section_id,d.name as section_name, sum(a.sumgrades) A​​S 标记来自 mdl_quiz_attempts a, mdl_quiz b, mdl_course_modules c, mdl_course_sections d WHERE a.userid=6 AND b.course=4 AND a.quiz=b.id AND c.instance=a.quiz AND c.module=14 AND a.sumgrades>0 AND d.id=c.section GROUP BY d.section"

我尝试了不同的 API 调用,主要是我想要的

$DB->get_records_sql($sql);

API 调用的结果毫无意义。有什么建议吗?

PS:这是moodle 2.2。

4

2 回答 2

2

我只是尝试做类似的事情,只是没有得到这些部分。您只需要课程和用户 ID。我希望这可以帮助你。

global $DB;

// get all attempts & grades from a user from every quiz of one course 
$sql = "SELECT qa.id, qa.attempt, qa.quiz, qa.sumgrades AS grade, qa.timefinish, qa.timemodified, q.sumgrades, q.grade AS maxgrade
        FROM {quiz} q, {quiz_attempts} qa
        WHERE q.course=".$courseid."
        AND qa.quiz = q.id
        AND qa.userid = ".$userid."
        AND state = 'finished'
        ORDER BY qa.timefinish ASC"; 
$exams = $DB->get_records_sql($sql);

// calculate final grades from sum grades
$grades = array();
foreach($exams as $exam) {
    $grade = new stdClass;
    $grade->quiz = $exam->quiz;
    $grade->attempt = $exam->attempt;
    // sum to final
    $grade->finalgrade = $exam->grade * ($exam->maxgrade / $exam->sumgrades);
    $grade->grademax = $exam->maxgrade;
    $grade->timemodified = $exam->timemodified;
    array_push($grades, $grade);
} 
于 2013-10-31T20:07:15.673 回答
0

这适用于最新的moodle版本。穆勒 2.9。尽管我仍然对更好的解决方案持开放态度,因为这确实是一种深入分析用户性能的方法。

于 2015-08-24T19:02:20.087 回答