Moodle 将数据从 ASSOC ARRAY 而不是数据对象保存到数据库


Moodle saving data to database from ASSOC ARRAY not Data Object

所以,我有这个关联数组,键是数据列,值是数据本身,其他框架如 kohana 使用 ORM 自动创建私有$data = aray() 并将其传递给数据库......所以如果

$class->data = "value";
$class->save() // $class->update()

这很容易,在带有ORM的框架中,但是moodle呢? 我尝试使用$DB->insert_record(),但stdClass很难创建。 如何在 Moodle 中将数组传递到数据库? 请问我需要帮助...这是我的班级

<?php
/**
 * Course completion Extention- student self marked - plugin
 *
 * @package   completion
 * @copyright 2012 Ekomerce Ltd
 * @author    Gavin Sanden <gavin@ekomerce.co.uk>
 */

completion_ext::$DB = $DB;
class completion_ext{
    private $data = array();
    public static $DB;
 /**
 * DB Table
 * @var string $table
 */
public $table = 'completion_ext';
/**
 * Array of required table fields, must start with 'id'.
 * @var array $required_fields
 */


 public static function fetch_all($params) {}
function __construct($data = null){
    if($data != null && is_array($data)){
        $this->data = $data;
    }
}
public static function get_from_user($user_id){
    $variables =  self::$DB->get_records('completion_ext',array(
        'user_id'=>$user_id
    ));
    $completion_array  = array();
    foreach($variables as $variable){
        $com = new completion_ext($variable);
        $completion_array[] = $com;
    }
    return $completion_array;
}
public static function exists($user, $course){
    return self::$DB->record_exists('completion_ext', array(
        'user_id'=>$user,
        'course'=>$course
    ));
}
public static function id_exists($id){
        return self::$DB->record_exists('completion_ext', array(
        'id'=>$id
    ));
}
public static function get_from_course($course, $user_id){
    $variables = self::$DB->get_record('completion_ext',array(
        'user_id'=>$user_id,
        'course'=>$course
    ));
    return new completion_ext($variables);
}
public function __set($dt, $vl){
    $this->data[$dt] = $vl;
}
public static function get_by_id($id){
    $variables = self::$DB->get_record('completion_ext',array(
        'id'=>$id
    ));
    return new completion_ext($variables);
}
public static function check_completion_from_user($user_id){
    self::$DB->record_exists($table, array(
        'user_id'=>$user_id
    ));
}
public function __get($dt){
    return $this->data[$dt];
}
public function save(){
    echo print_r($this->data);
}
public function update(){
    self::$DB->update_record("completion_ext", $this);
}

}?>

如果你只需要一个 stdClass 对象,它很简单:

$myObject = (object) array('propertyName' => 'value');

转换运算符(object)创建一个 stdClass 实例,并将所有数组索引作为属性。