0

所以,我有这个关联数组,键是数据列,值是数据本身,其他框架(如 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);
}

} ?>

4

1 回答 1

0

如果您只需要一个 stdClass 对象,那很简单:

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

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

于 2012-06-04T12:05:25.680 回答