Active Record Codeigniter中的自定义错误

时间:2014-06-18 04:57:17

标签: php mysql codeigniter activerecord custom-errors

我正在使用HMVC。我的问题很简单。我们如何捕获活动记录中的错误? 我们如何从模型(活动记录)向控制器返回自定义错误?

实际上,msn列是唯一的,所以当我输入重复值时,它的显示错误就像

错误号码:1062

为密钥'msn'重复输入'3696003284'

但我希望显示自定义错误而不是此。

我的简单代码是:

function insert_data($msn_number, $date_val, $min_val, $max_val, $avg_val,$counter)
{
    for($i=0;$i<$counter;$i++)
    {
        $data = array(
            'msn'     => $msn_number[$i],
            'date'    => $date_val[$i],
            'min_val' => $min_val[$i],
            'max_val' => $max_val[$i],
            'average' => $avg_val[$i]
        );
        $result = $this->db->insert('storage_data', $data);
        if(!isset($result))
         {
           echo "custom Error";
          }

    }
 }

}

我想知道这个问题的答案,请帮助我!

1 个答案:

答案 0 :(得分:0)

你可以试试这个:

$result = $this->db->insert('storage_data', $data);
if (!$result) {
    $data['msg'] = $this->db->_error_message();
    $this->load->view('viw_db_error', $data); // Create a viw_db_error.php view
}

确保DB_DEBUG文件中的FALSE设置为application/config/database.php,否则如果发生mysql错误,将暂停执行。

<强>更新

或者,您可以在每次插入新记录之前查询该记录,但这样会非常昂贵,因为您在循环内执行它并且它会发送许多查询/请求:

$q = $this->db->query("select msn from storage_data where msn = $msn_number[$i]");
if( $q->num_rows() ) {
    // It already exists so maybe display a message
}