tl;博士尝试通过mysql或官方moodle api通过课程模块获取课程模块实例。不过,我的解决方案最终看起来相当棘手,所以我想要一些建议。
嗨Moodle的人
我正在尝试为mdl_course_modules中的每一行检索相应的课程模块实例,在此上下文中的实例将是来自mdl_quiz、mdl_wiki或其他课程模块实例的一行。
我已经尝试了一些事情,我期望工作的是:
function get_all_course_modules($course_id) {
global $DB;
$course = $DB->get_record('course', array('id' => $course_id));
$mod_info = get_fast_modinfo($course);
}
我无法从$mod_info获取课程模块实例。
所以我试着做一些自定义mysql,
SELECT course.id, course.fullname, cm.course, cm.section, m.name
FROM mdl_course AS course
JOIN mdl_course_modules AS cm ON cm.course = course.id
JOIN mdl_modules AS m ON m.id = cm.module
JOIN CONCAT('mdl_', m.name) AS module_type ON ...somethingsomething
WHERE course.id = 2;
sql还没有完全完成,我偶然发现我事先不知道所有不同的课程模块,这意味着我必须动态地使用course_module的名称来选择我要加入的实例表,或者只是在所有可能的课程模块实例表上LEFT join,但这将需要很长时间,如果有人放入一个新的课程模块实例,就会停止工作。
现在我正在做以下事情:
$result = array();
$course_mods = get_course_mods($course_id);
if($course_mods) {
foreach($course_mods as $course_mod) {
$DB->get_records_sql('some sql that selects the instance');
}
}
return $result;
最后一段代码最终会起作用,我将能够从$course_mod变量中动态创建查询,如$course-mod->实例、$coursemode->mod_name等。
但我认为这似乎很难。你们中有人成功地以更简单的方式获得了course_module实例吗??
谢谢!!
这是我最终用来检索课程模块实例的函数,它不那么漂亮,但不管怎样。
function get_all_course_modules($course_id) {
global $DB;
$course_mods = get_course_mods($course_id);
$result = array();
if($course_mods) {
foreach($course_mods as $course_mod) {
$course_mod->course_module_instance = $DB->get_record($course_mod->modname, array('id' =>$course_mod->instance ));
$result[$course_mod->id] = $course_mod;
}
}
return $result;
}