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
Форумы портала PHP.SU :: Версия для печати :: Сформировать UPDATE по json
Форумы портала PHP.SU » » Вопросы новичков » Сформировать UPDATE по json

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

1. Грачи прилетели - 04 Февраля, 2022 - 06:58:01 - перейти к сообщению
Добрый день!

Помогите, пожалуйста, советом, как сформировать 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.  
2. DlTA - 04 Февраля, 2022 - 10:46:18 - перейти к сообщению
для облегчения записи и красивого отображения в редакторах

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. */
3. Мелкий - 04 Февраля, 2022 - 11:37:18 - перейти к сообщению
для облегчения записи и по очевидным другим причинам - используйте, блин, уже, наконец, prepared statements api вместо конкатенации данных в текст запроса.

 

Powered by ExBB FM 1.0 RC1