Code Igniter在插入数据时捕获错误(Active Record)

时间:2011-11-20 15:30:07

标签: php database activerecord error-handling codeigniter-2

我使用以下代码将数据插入我的数据库:

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

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

如何确保流程成功并向用户显示确认消息,否则会显示错误消息?

2 个答案:

答案 0 :(得分:5)

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

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';
}
评论后

更新

我相信你的三个insert_batch()在三个不同的表上,所以每个表都要检查一下。无论如何,令我困惑的是这个检查的原因。查询不会随机失败:可能他们应该从不失败,当他们这样做时你会通过错误(记录或显示)知道。

答案 1 :(得分: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;
        }