编辑MySQL数据库表中的数据,CakePHP中没有主键

时间:2015-03-25 12:37:51

标签: php mysql cakephp

Windows 系统上使用 cakephp-2.6.3

我只需要编辑我在ABCData/index.php文件中列出的MySQL数据库表中的行数据。

控制器     

    public function index() {
        $this->set('abcdata', $this->ABCData->find('all'));
    }

    public function edit($custom_id = null) {
        if (!$custom_id) {
            throw new NotFoundException(__('Invalid entry'));
        }

        $post = $this->ABCData->findById($custom_id);
        if (!$abcdata) {
            throw new NotFoundException(__('Invalid entry'));
        }

        if ($this->request->is(array('post', 'put'))) {
            $this->ABCData->custom_id = $custom_id;
            if ($this->ABCData->save($this->request->data)) {
                $this->Session->setFlash(__('Your ABCData has been updated.'));
                return $this->redirect(array('action' => 'index'));
            }
            $this->Session->setFlash(__('Unable to update your ABCData.'));
        }

        if (!$this->request->data) {
            $this->request->data = $abcdata;
        }
    }
}

模型

class ABCData extends AppModel {
    public $primaryKey = 'custom_id';
}

index.ctp

    <h3>ABCData list</h3>
<table>
    <tr>
        <th></th>
        <th>field_1</th>
        <th>field_2</th>
        <th>field_3</th>
        <th>...</th>
        <th>...</th>
        ...
    </tr>

    <?php foreach ($abcdata as $abc): ?>
    <tr>
        <td><?php echo $this->Html->link('Edit', array('action' => 'edit', $abc['ABCData']['custom_id']));?></td>
        <td><?php echo $abc['ABCData']['field_1']; ?></td>
        <td><?php echo $abc['ABCData']['field_2']; ?></td>
        <td><?php echo $abc['ABCData']['field_3']; ?></td>
        <td>...</td>
        <td>...</td>
        ...
    </tr>
    <?php endforeach; ?>
    <?php unset($abcdata); ?>
</table>

edit.ctp

<h1>Edit ABCata</h1>
<?php
    echo $this->Form->create('ABCata');
    echo $this->Form->input('title');
    echo $this->Form->input('body', array('rows' => '16'));
    echo $this->Form->input('custom_id', array('type' => 'hidden'));
    echo $this->Form->end('Save ABCata');
?>

我所拥有的是一个包含foreign key字段的表格。

此处custom_id仅为唯一字段。

我收到此错误:

  

数据库错误

     

错误:SQLSTATE [42S22]:找不到列:1054未知列   'where子句'中的'ABCData.id'   ...   ...

请帮忙。

1 个答案:

答案 0 :(得分:1)

如评论中所述,如果您的模型中没有ID,则无法按ID进行搜索。你好吗

$post = $this->ABCData->findByCustomId($custom_id);

根据Cake约定,您可以指定类似

的条件
$post = $this->ABCData->find('first', array('conditions' =>
                                           array('ABCData.custom_id' => $custom_id)));