2011-07-05 95 views
1

我有一个表单将数据提交给CodeIgniter应用程序(CI v。2.0.2)中的数据库。我们允许用户通过使用新值重新提交记录然后进行更新来“编辑”记录。提交时,表单调用投票控制器的创建方法。在create方法中,我们检查是否已经有一个基于条目代码和用户ID的记录。如果有,我们更新;否则我们创建一个新的记录。创作工作得很好;这只是我遇到问题的更新。这是代码。CodeIgniter中的活动记录更新问题

视图

<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); 
    } 

我知道它使它成为了UPD ateRecord方法,因为log_message输出在我的日志文件中,显示正确的vote_id(返回记录的自动增量字段)。但我得到的浏览器如下:

enter image description here

任何人都可以点我在这里向正确的方向?我在我的配置文件中显示错误,并且在发生SQL错误时,我不认为这是SQL错误。但是我不知道在这个微小的函数中会发生什么事情。我的下一步是跳过活动记录更新并仅使用标准查询,但我想知道是什么导致了这个问题,即使我能以其他方式使用它。

回答

2

此行站了出来:

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

你的意思呢?

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

是的,当然这就是我的意思!愚蠢的小错误,但我可以盯着它几个星期,而不是自己找到它。谢谢! – EmmyS

+0

错误日志是你最好的朋友。 –