Проблема с обновлением активной записи в CodeIgniter

У меня есть форма, которая отправляет данные в базу данных в приложении CodeIgniter (CI v. 2.0.2). Мы разрешаем пользователям «редактировать» записи, заставляя их повторно отправлять запись с новыми значениями, а затем выполняя обновление. При отправке форма вызывает метод create контроллера голосования. Внутри метода create мы проверяем, есть ли уже запись на основе кода входа и идентификатора пользователя. Если есть, обновляем; в противном случае мы создаем новую запись. Создание работает просто отлично; проблема только с обновлением. Вот код.

просмотреть

<div id="vote_form">
            <?php
           $hidden = array('dot_judge_id' => $this->session->userdata('dot_judge_id'));

            echo form_open('vote/create'); 
                $entry_code_data = array(
                    'name' => 'entry_code',
                    'id' => 'entry_code',
                    'value' => set_value('entry_code')
                );

                echo form_hidden($hidden);

                $score_options = array('1'=>'1 (lowest)', '2'=>'2','3'=>'3', '4'=>'4','5'=>'5 (highest)');

                ?>
                <p><label for="entry_code">Entry code: </label><?php echo form_input($entry_code_data); ?></p>
                <p><label for="q1">Question 1: </label><?php echo form_dropdown('q1', $score_options, ''); ?></p>
                <p><label for="q2">Question 2: </label><?php echo form_dropdown('q2', $score_options, ''); ?></p>
                <p><label for="q3">Question 3: </label><?php echo form_dropdown('q3', $score_options, ''); ?></p>
                <p><label for="q4">Question 4: </label><?php echo form_dropdown('q4', $score_options, ''); ?></p>
                <p><label for="q5">Question 5: </label><?php echo form_dropdown('q5', $score_options, ''); ?></p>

                <p><?php echo form_submit('submit', 'Submit vote'); ?></p>                

            <?php echo form_close(); ?>
            <?php echo validation_errors(); ?>


        </div>

контроллер

function create() {
                $id = $this->input->post('entry_code');
                $judge_id = $this->input->post('dot_judge_id');

        $data = array(
            'entry_code' => $id,
            'dot_judge_id' => $judge_id,
            'q1' => $this->input->post('q1'),
                        'q2' => $this->input->post('q2'),
                        'q3' => $this->input->post('q3'),
                        'q4' => $this->input->post('q4'),
                        'q5' => $this->input->post('q5'),

        );

                //first check to see if there's already a record for this judge/entry
                //if so, update. Otherwise, insert
                $vote_id = $this->vote_model->getEntryById($id, $judge_id);
                if($vote_id) {
                        log_message('debug', 'vote id exists: '.$vote_id);
                        $this->vote_model->updateRecord($data, $vote_id);

                }
                else {
                        log_message('debug', 'vote id does not exist; creating new');
                        $this->vote_model->createRecord($data);
                }

                /*
                 after submission, go to another page that gives choices - review entries, submit another entry, log out
                */
                $data['msg'] = "Entry submitted";
        $this->menu();

    }

модель

function getEntryByID($id, $judge_id) {
        //determine if record already exists for entry/judge
        $sql = 'SELECT vote_id from dot_vote WHERE entry_code = ? AND dot_judge_id = ?';
        $query = $this->db->query($sql, array($id, $judge_id));

        if($query->num_rows() == 1) {
               $row = $query->row();
               return $row->vote_id;
        }
         else {
            return false;
         }
    }


    function createRecord($data) {
        $this->db->insert('dot_vote', $data);
        return;
    }

    function updateRecord($data, $vote_id) {
        log_message('debug', 'vote id is passed: '.$vote_id);
        $this->db->where('vote_id', $vote_id);
        $this->update('dot_vote', $data);
    }

Я знаю, что это попадает в метод updateRecord, потому что вывод log_message находится в моем файле журнала, отображая правильный голос_идентификатора (поле автоинкремента возвращаемой записи). Но то, что я получаю в браузере, следующее:

введите здесь описание изображения

Может ли кто-нибудь указать мне правильное направление здесь? У меня есть отображение ошибок в моем файле конфигурации, и при их возникновении возникают ошибки SQL, поэтому я не думаю, что это ошибка SQL. Но я понятия не имею, что может происходить в этой крошечной функции, которая вызывает это. Мой следующий шаг — пропустить активное обновление записи и просто использовать стандартный запрос, но я хотел бы знать, в чем здесь проблема, даже если я смогу заставить ее работать другим способом.


person EmmyS    schedule 05.07.2011    source источник


Ответы (1)


Эта строка выделялась:

$this->update('dot_vote', $data);

Вы имеете в виду это?

$this->db->update('dot_vote', $data);
person cwallenpoole    schedule 05.07.2011
comment
Да, конечно, это то, что я имел в виду! Глупая маленькая ошибка, но я мог бы смотреть на нее неделями и сам не нашел бы ее. Спасибо! - person EmmyS; 06.07.2011