2011-11-20 69 views
3

我使用下面的代码插入数据到我的数据库:上插入数据(活动记录)代码点火器捕获错误

$this->db->set('event_id', $event_id); 
... 
$this->db->set('creator_id', $creator_id); 

$this->db->insert('event'); 

我怎样才能确保过程是成功的,并显示在用户的确认信息,其他错误信息?

+1

是什么的var_dump'输出($这个 - > DB->插件( '事件'));'? – Shoe

回答

5

嗯,IIRC该方法返回如果成功的真正的,所以你可以用一个简单的

if($this->db->insert('event')) 
{ 
    echo 'Row succesfully inserted!'; 
} 

要不要去,你可能永远算affected rows

//.... 
$this->db->insert('event'); 
if($this->db->affected_rows() > 0) 
{ 
    echo 'row succesfully inserted'; 
} 

UPDATE后评论:

我相信你的三个insert_batch()在三个不同的表上,所以检查应该放在每一个。无论如何,有什么令我费解的是behin这个检查的原因..查询不会随机失败:可能他们应该从来没有失败,当他们做时,你会通过错误(记录或dislayed)知道。

+0

之后我有两个insert_batch($ array),我必须在做另一个之前测试每个插入吗?或者我可以只测试它们全部3,即 'if($ this-> db-> insert('event')&& $ this-> db-> insert_batch($ arr1)&& $ this-> db-> insert_batch( $ arr2)){...}' – lodhb

+0

@lodhb我更新了我的回答 –

+0

已解决,谢谢! – lodhb

0

“如果您需要获取发生的最后一个错误,error()方法将返回一个包含其代码和消息的数组。” https://www.codeigniter.com/userguide3/database/queries.html

$insert = $this->db->insert('event'); 

      if(!$insert){ 

       $error = $this->db->error(); // Has keys 'code' and 'message' 
       echo "<BR><BR>"; 
       print_r($error); 
       echo "<BR><BR>"; 
      } 

      echo "Error contact the database admin."; 
      die(); 

     }else{ 

      echo "SUCCESSFULLY INSERTED ITEM"; 
      return TRUE; 
     }