Code Igniter перехватывает ошибки при вставке данных (Active Record) - PullRequest
3 голосов
/ 20 ноября 2011

Я вставляю данные в свою базу данных, используя следующий код:

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

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

Как я могу убедиться, что процесс прошел успешно, и показать пользователю сообщение с подтверждением, иначе сообщение об ошибке?

Ответы [ 2 ]

5 голосов
/ 20 ноября 2011

Хм, IIRC метод возвращает true, если успешно, так что вы можете пойти с простым

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

В противном случае вы можете всегда считать затронутые строки :

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

ОБНОВЛЕНИЕ после комментария:

Я полагаю, что ваши три insert_batch () находятся на трех разных таблицах, поэтому проверка должна быть закрыта для каждой. Во всяком случае, то, что озадачивает меня, является причиной этой проверки. Запросы не могут случайно произойти: возможно, они должны никогда не удастся, и когда они это сделают, вы узнаете об ошибках (зарегистрированных или отключенных).

0 голосов
/ 12 сентября 2017

"Если вам нужно получить последнюю произошедшую ошибку, метод 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;
        }
...