У меня есть относительно простая модель записей только с пятью полями:
- id
- тип (какой тип данных у этой записи)
- количество (скольконезависимо от типа)
- единица (единица измерения типа)
- дата (datettime, когда эта запись была введена)
- user_id (идентификатор пользователя, который вводит
Итак, ничего сложного. Теперь в одной форме может быть несколько записей (как уже существующих, так и только что созданных), форма расширяется с помощью вызовов ajax.
Когда яотправить форму $this->data
выглядит следующим образом:
Array
(
[Entry] => Array
(
[date] => 2011-01-07
[0] => Array
(
[id] => 1
[type] => Eat
[amount] => 1 Steak, one baked potatoe
[unit] => lunch
[time] => Array
(
[hour] => 13
[min] => 31
)
)
[1] => Array
(
[type] => weight
[amount] => 78.5
[unit] => KG
[time] => Array
(
[hour] => 22
[min] => 22
)
)
)
)
Первая запись в $this->data['Entry']['date']
- это дата, которая должна использоваться ВСЕМИ записями. И так как также отсутствует user_id, я создал "beforeSave""функция в модели входа. Это выглядит следующим образом:
function beforeSave() {
App::import('Component','Session');
$this->Session = new SessionComponent();
if (isset($this->data) && isset($this->data['Entry'])) {
$date = $this->data['Entry']['date'];
unset($this->data['Entry']['date']);
foreach ($this->data['Entry'] as $n => $entry) {
if (is_array($entry)) {
$this->data['Entry'][$n]['date'] = $date . ' ' . $entry['time']['hour'] . ':' . $entry['time']['min'] . ':00';
$this->data['Entry'][$n]['user_id'] = $this->Session->read('Auth.User.id');
}
}
debug($this->data);
}
return true;
}
Я удаляю дату, добавляю ее вместе с записью времени пользователя, создавая таким образом запись даты и времени mysql и добавляя user_idвошел в систему пользователя. Прямо, действительно. Полученный массив (как вывод этой последней debug()
) выглядит следующим образом:
Array
(
[Entry] => Array
(
[0] => Array
(
[id] => 1
[type] => Eat
[amount] => 1 Steak, 1 baked potatoe
[unit] => lunch
[time] => Array
(
[hour] => 09
[min] => 31
)
[date] => 2011-01-07 09:31:00
[user_id] => 2
)
[1] => Array
(
[type] => Weight
[amount] => 78.5
[unit] => KG
[time] => Array
(
[hour] => 22
[min] => 22
)
[date] => 2011-01-07 22:22:00
[user_id] => 2
)
)
)
Таким образом, это выглядит именно так, как я хочу, чтобы он выглядел, и его следует легко сохранить.Но когда я использую $this->Entry->saveAll($this->data['Entry']
) для сохранения всех записей, он не только не работает, но и когда я отлаживаю $this->data
непосредственно после saveAll, он выглядит точно так же, как и до функции saveAll - дата возвращается в массив,записи не имеют дату или запись user_id.
Я вижу, что перед вызовом SaveS я вижу, что он меняется $this->data
, но где-то между концом beforeSave и использованием "saveAll" все мои изменения теряются и $this->data
возвращается кэто оригинальное состояние.Следовательно, сохранение не происходит.