Laravel: обновить вложенный объект jsonPhp

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Laravel: обновить вложенный объект json

Сообщение Anonymous »

У меня в базе данных есть столбец для сохранения настроек пользователей. Вот как выглядит структура данных:

Код: Выделить всё

{"email":{"subscriptions":"{\"Foo\":true,\"Bar\":false}"}}
Я использую переключатель vue, чтобы изменить статус каждого свойства (истина/ложь). Кажется, все работает, однако при сохранении я удаляю структуру и сохраняю обновленные значения следующим образом:

Код: Выделить всё

{\"Foo\":true,\"Bar\":false}"}
php

Код: Выделить всё

$user = auth()->user();
$array = json_decode($user->preferences['email']['subscriptions'], true);
dd($array);
Меня это поняло:

Код: Выделить всё

array:2 [
"Foo" => true
"Bar" => false
]
Пока все хорошо...

Код: Выделить всё

$preferences = array_merge($array, $request->all());

dd($preferences);
Понимает меня:

Код: Выделить всё

array:2 [
"Foo" => true
"Bar" => true
]
Отлично! Значения теперь подбирают значения, переданные из запроса axios. Следующий; обновить данные пользователя:

Код: Выделить всё

$user->update(compact('preferences'));
Теперь мои данные выглядят так:

Код: Выделить всё

{"Foo":true,"Bar":true}
Значения больше не являются вложенными; Я удалил электронную почту и подписки.

Я пробовал это:

Код: Выделить всё

$user->update([$user->preferences['email']['subscriptions'] => json_encode($preferences)]);
Но, похоже, данные не сохраняются. Как я могу использовать переменную $preferences для обновления данных и сохранения правильной вложенности данных?

Подробнее здесь: https://stackoverflow.com/questions/586 ... son-object
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»