使用CodeIgniter更新MySQL表中的行

时间:2011-11-16 20:36:36

标签: php mysql codeigniter

所以我一般都是PHP和MySQL的新手,以及MVC应用程序。请原谅我,如果这是一个已经回答的问题,我找不到任何清晰的东西,并展示了完整的MVC流程。

所以我有一个HTML表格,其中包含由a中的数据填充的输入,我为每行生成一个表单作为单独的表,并为每个表生成一个提交按钮。我希望更新按钮只更新与生成的表单关联的行。

如果从模型中删除this->db->where('id', $id);,它会使用相同的信息更新表中的所有行,并且不会更新任何内容。

任何帮助或实现此目的的替代方法都将非常受欢迎。我认为控制器功能也不是很糟糕。

谢谢。

查看

<?php foreach($log->result() as $row): ?>
<?=form_open('hq/update_entry');?>
    <table class="editLog">
        <tr>
            <td><?php 
                $data = array(
                    'name' => 'no',
                    'value' => $row->no
                );
                echo form_input($data);
                ?></td>
            <td><?php 
                $data = array(
                    'name' => 'date',
                    'value' => $row->date
                );
                echo form_input($data);
                ?></td>
            <td><?php 
                $data = array(
                    'name' => 'artist',
                    'value' => $row->artist
                );
                echo form_input($data);
                ?></td>
            <td><?php 
                $data = array(
                    'name' => 'title',
                    'value' => $row->title
                );
                echo form_input($data);
                ?></td>
            <td><?php 
                $data = array(
                    'name' => 'long',
                    'value' => $row->long
                );
                echo form_input($data);
                ?></td>
            <td><?php 
                $data = array(
                    'name' => 'lat',
                    'value' => $row->lat
                );
                echo form_input($data);
                ?></td>
                <td>
            <?php
                echo form_hidden('id', $row->id);
                $data = array(
                    'class' => 'updateSubmit',
                    'value' => '✚'
                );
                echo form_submit($data);
            ?></td>
        </tr>
    </table>
<?=form_close();?>

CONTROLLER

function update_entry()
{
    $this->load->model('update_entry_model');

    if($query = $this->update_entry_model->update())
    {
        $this->index();
    }
    else
    {
        redirect('hq');
    }
}

MODEL

<?php
    class Update_entry_model extends CI_Model {
        function update()
        {
            $data = array(
                'no' => $this->input->post('no'),
                'date' => $this->input->post('date'),
                'artist' => $this->input->post('artist'),
                'title' => $this->input->post('title'),
                'long' => $this->input->post('long'),
                'lat' => $this->input->post('lat')
            );
            $this->db->where('id', $id);
            $this->db->update('entries', $data);
        }
    }

1 个答案:

答案 0 :(得分:3)

在没有进行进一步调查的情况下,我发现在模型函数update()中,您缺少

$id = $this->input->post('id');

添加this->db->where('id', $id);不会更新任何内容的原因是因为$ id当前未设置为任何值。