0
我试图用DataMapper创建一个模型,但是当我用save()
插入一些新数据时,它会返回一个错误。PHP - CodeIgniter - DataMapper - 保存错误()
错误
数据库出错
您必须使用 “设置” 方法来更新条目。
文件名:C:\ WAMP \ WWW \网站\ SYSTEM \数据库\ 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);
}
你能告诉我们'1174'的代码行吗? – eggy 2014-10-28 00:42:47
是的,这条线是在该方法中插入,恰好在此条件: 如果(计数($这个 - > ar_set)== 0){ 如果 ($这个 - > db_debug) { /*线1174 */\t return $ this-> display_error('db_must_use_set'); } return FALSE; } – Gaetan 2014-10-28 00:50:04