PHP - CodeIgniter - DataMapper - save()出错

时间:2014-10-28 00:32:53

标签: php codeigniter save datamapper

我尝试使用DataMapper创建模型,但是当我使用save()插入一些新数据时,它会返回错误。

错误

  

发生数据库错误

     

你必须使用" set"更新条目的方法。

     

文件名:C:\ wamp \ www \ website \ system \ database \ DB_active_rec.php

     

行号:1174

我在auto-increment的数据库中有一个ID,我使用了控制器的方法铭文。

代码

<?php

    class Utilisateur_model extends DataMapper {

        var $table = 'utilisateur';

        var $validation = array(

            'login' => array(

                'label' => 'Login',
                'rules' => array('required', 'unique', 'trim')
            ),
            'mdp' => array(

                'label' => 'Mot de passe',
                'rules' => array('required', 'trim')
            ),
            'nom_utilisateur' => array(

                'label' => 'Nom',
                'rules' => array('required', 'trim')
            ),
            'prenom_utilisateur' => array(

                'label' => 'Prenom',
                'rules' => array('required', 'trim')
            ),
            'email' => array(

                'label' => 'Email',
                'rules' => array('required', 'valid_email', 'trim')
            ),
            'adresse' => array(

                'label' => 'Adresse',
                'rules' => array('required', 'trim')
            )
        );


        public static function inscription($donnees) {

            $u = new Utilisateur_model();

            $u->login = $donnees['login'];
            $u->mdp = $donnees['mdp'];
            $u->nom_utilisateur = $donnees['nom'];
            $u->prenom_utilisateur = $donnees['prenom'];
            $u->email = $donnees['email'];
            $u->adresse = $donnees['adresse'];

            if($u->save()) {

                return array(true);
            }
            else {

                return array(false, $u->error->string);
            }
        }
    }
?>

第1174行是这种方法:

function insert($table = '', $set = NULL)
{
    if ( ! is_null($set))
    {
        $this->set($set);
    }

    if (count($this->ar_set) == 0)
    {
        if ($this->db_debug)
        {
            return $this->display_error('db_must_use_set'); //line 1174
        }
        return FALSE;
    }

    if ($table == '')
    {
        if ( ! isset($this->ar_from[0]))
        {
            if ($this->db_debug)
            {
                return $this->display_error('db_must_set_table');
            }
            return FALSE;
        }

        $table = $this->ar_from[0];
    }

    $sql = $this->_insert($this->_protect_identifiers($table, TRUE, NULL, FALSE), array_keys($this->ar_set), array_values($this->ar_set));

    $this->_reset_write();
    return $this->query($sql);
}

1 个答案:

答案 0 :(得分:0)

好的,我发现了为什么...... 因为数据库中的列名全部是大写的,而且在模型中都是小写的...... 但现在它的工作:D