липсва поле за данни за публикуване на cakephp в израза за актуализиране на SQL

Имате проблеми с cakephp да актуализирате запис.

Код на контролера:

public function viewBenefit($id) {
    if ($this->request->is('post')) {
        $this->set('post', $this->request->data);
        $this->Benefit->id = $id;
        if ($this->Benefit->save($this->Benefit->data)) {
            $myVars['Sucsess'] = TRUE;
            $this->Session->setFlash('Updates Saved');
        } else {
            $myVars['NewID'] = 0;
            $myVars['Sucsess'] = False;
            $this->Session->setFlash('There was an error.');
        }
    }

    $this->Benefit->recursive = 2;
    $this->Benefit->id = $id;
    $this->set('benefit', $this->Benefit->read());
}

Подходящ код за преглед:

<?php echo $this->Form->create('Benefit',array('action'=>'edit','url' => '#')); ?>
<?php echo $this->Form->input('id',array('type'=>'hidden')) . "\n"; ?>
<?php echo $this->Form->input('short_description',array('type'=>'textarea')) . "\n"; ?>
<?php echo $this->Form->end(); ?>

ЗАБЕЛЕЖКА: Формулярът се предава чрез JS

POST данни (чрез debug($post); )

array(
    'Benefit' => array(
        'id' => '1952e98e-f589-47d4-b458-11a1bd58ba3b',
        'short_description' => '<p>This is great sample insurance 321321</p>'
    )
)

Изявление за SQL АКТУАЛИЗАЦИЯ:

UPDATE `c16memberdev`.`benefits` SET `modified` = '2012-12-04 10:45:16' WHERE `c16memberdev`.`benefits`.`id` = '1952e98e-f589-47d4-b458-11a1bd58ba3b'

Както можете да видите, полето "short_description" не се добавя към SQL оператора и следователно данните не се добавят към базата данни. Благодаря за вашата помощ.


person mbryant    schedule 04.12.2012    source източник
comment
къде се настройват $this-›Benefit-›data?   -  person Colby Guyer    schedule 04.12.2012


Отговори (1)


Опитайте да промените

$this->Benefit->save($this->Benefit->data)

to

$this->Benefit->save($this->request->data)
person Colby Guyer    schedule 04.12.2012
comment
Това беше, благодаря сър. - person mbryant; 04.12.2012