@XenK

Yii2 Обновить/Добавить записи в базу?

Есть большой массив, порядка 3000. Выглядит так:
array(
'test1' => 23
'test2' => 35
...
)


Нужно добавить эти значения в БД (колонки: test, val), значение val может меняться, т.е массив не постоянный. Если test1 уже есть то обновляем занчение val, если нет то добавляем новую запись.

Пробовал сделать так:
foreach ($arr as $test => $val) {
            $item = Arr::findOne(['test' => $test]);
            if (!empty($item)) {
                $item->test = $test;
                $item->val = $val;
            } else {
                $item = new Arr();
                $item->test = $test;
                $item->val = $val;
            }
            $item->save();
        }


Но так добавляется только одна запись. Как лучше это сделать?
  • Вопрос задан
  • 189 просмотров
Пригласить эксперта
Ответы на вопрос 1
latteo
@latteo
$this->db = Yii::$app->db; 
    $sql = $this->db
      ->QueryBuilder
      ->batchInsert('table_name', ['test', 'val'], $arr);
    //У меня уникальность по первому полю и я хочу избежать ошибок, которые прервут вставку:
    $sql = 'INSERT IGNORE' . mb_substr($sql, strlen('INSERT'));
    $inserted = $this->db->createCommand($sql)->execute();
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
YCLIENTS Москва
от 200 000 до 350 000 ₽
Ведисофт Екатеринбург
от 25 000 ₽
Бюро Цифровых Технологий Санкт-Петербург
от 120 000 до 180 000 ₽
03 мая 2024, в 16:26
3000 руб./за проект
03 мая 2024, в 16:09
1200 руб./за проект
03 мая 2024, в 16:06
3000 руб./за проект