Пипл! Ай нид хелп. Есть какая-то возможность без подгрузки модели

через find указать модели что она не новая и что ее надо апдейтить, а не инсертить?

4 ответов

21 просмотр

Надо определиться - кто назначает ID. Если база - т.е. если поле стоит auto_increment - то указывать его в данных load не надо, его должна присвоить база при выполнении insert. Если id назначается приложением - скажем, такое может быть при использовании uuid - то именно приложение должно отвечать за то, что такой id в базе точно отсутствует.

Используйте updateAll к примеру для обновления, ID используйте как определения того, куда надо внести изменения

Вот пример // UPDATE DB_name SET status = 1 WHERE 'id' = 1 DB_name::updateAll(['status' => 1], ['id' => 1]);

https://github.com/yiisoft/yii2/blob/ab1c653fb788383c4b8b628bc1f0021b06316427/framework/db/ActiveRecord.php#L507

Похожие вопросы

Обсуждают сегодня

Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
3
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
у кого сколько оперативы на базе данных ?
АДИЛЬБЕК
4
Через бот апи возможно получить ID стикерпака? Не ссылку.
Vexylon [АФК до 09.09]
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
В тг можно спарсить всех кто пишет в группе? Если список участников скрыт
S
3
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Как можно это ускорить? Суть, есть база грязная, в ней туча дублей, дубли разные могут содержать дополнительные полезные поля. Нужно найти эти дубли, выбрать из них самый пол...
Денис Александрович
2
Карта сайта