Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Сформировать UPDATE по json

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Грачи прилетели
Отправлено: 04 Февраля, 2022 - 06:58:01
Post Id



Гость


Покинул форум
Сообщений всего: 81
Дата рег-ции: Май 2015  


Помог: 0 раз(а)




Добрый день!

Помогите, пожалуйста, советом, как сформировать UPDATE после парсинга json? Никак не могу представить итоговый вариант...

мой json на входе

CODE (htmlphp):
скопировать код в буфер обмена
  1. $f_json='{
  2. "version":1,
  3. "parts":[
  4. {"top":"test","part":0,"rep":[11,12,6]},
  5. {"top":"test","part":1,"rep":[6,11,15]},
  6. {"top":"test","part":2,"rep":[15,6,14]}
  7. ]
  8. }
  9. ';
  10.  


получилось разобрать его так на составляющие:

CODE (htmlphp):
скопировать код в буфер обмена
  1. $arr_prcnt = json_decode($f_json, true) ?: [];
  2. $jsonObj= $arr_prcnt["parts"];
  3. foreach($jsonObj as $key =>$obj)
  4. {
  5.         echo $obj["top"] . "    " . $obj["part"] . "    ";
  6.         foreach($obj["rep"] as $key =>$obj_repl)
  7.         {
  8.                 echo $obj_repl . "      ";
  9.         }
  10.         echo "<br />";
  11. }
  12.  


Но мне на выходе нужно в цикле проапдейтить записи в таблице
UPDATE public.tops_part SET topk='test', "part"=0, rep1=11, rep2=12, rep3=16 WHERE topk='test' AND part=0; и т.д.

не могу понять, как сформировать итоговый UPDATE

P`S
Вроде получилось :
PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3. foreach($jsonObj as $key =>$obj)
  4. {
  5. //echo $obj["top"] . "  " . $obj["part"] . "    ";
  6. $query= "UPDATE public.tops_part SET topk='".$obj['top']."', part=".$obj['part'].", rep1=".$obj['rep'][0].", rep2=".$obj['rep'][1].", rep3=".$obj['rep'][2]." WHERE topk='".$obj['top']."' AND part=".$obj['part'];
  7.  
  8. echo "<br />";
  9. echo $query;
  10. }
  11.  
  12.  

(Отредактировано автором: 04 Февраля, 2022 - 07:29:14)

 
 Top
DlTA
Отправлено: 04 Февраля, 2022 - 10:46:18
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2952
Дата рег-ции: Окт. 2010  


Помог: 53 раз(а)




для облегчения записи и красивого отображения в редакторах

PHP:
скопировать код в буфер обмена
  1. $pole = 'asd';
  2. $tab = 'sdf';
  3. $val = 'fds';
  4. $listVal = ['rwe'];
  5.  
  6. $req = "
  7. SELECT `{$pole}`
  8. FROM
  9.  `{$tab}`
  10. WHERE
  11.  `as`!='{$val}'
  12.  AND `fd`='{$listVal[0]}'
  13. ";
  14.  
  15. /*
  16. так будет более наглядней
  17. */

(Отредактировано автором: 04 Февраля, 2022 - 10:53:04)

 
 Top
Мелкий Супермодератор
Отправлено: 04 Февраля, 2022 - 11:37:18
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




для облегчения записи и по очевидным другим причинам - используйте, блин, уже, наконец, prepared statements api вместо конкатенации данных в текст запроса.


-----
PostgreSQL DBA
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB