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

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

1. maragon - 29 Января, 2014 - 10:14:42 - перейти к сообщению
Есть в бд поле users
вытаскиваю его, на выходе |u1|u2|u225|
Как это можно вогнать в foreach? Чтобы потом для u1,u2,u... сделать запрос?
CODE (htmlphp):
скопировать код в буфер обмена
  1. foreach($users AS $row){
  2. $db->query("INSERT...");
  3. }
2. EuGen - 29 Января, 2014 - 10:20:05 - перейти к сообщению
Использовать таблицу-связку и не записывать в одно поле несколько значений через разделитель. Тогда простой JOIN даст все нужные данные для INSERT..SELECT
3. maragon - 29 Января, 2014 - 10:26:27 - перейти к сообщению
EuGen пишет:
Использовать таблицу-связку и не записывать в одно поле несколько значений через разделитель. Тогда простой JOIN даст все нужные данные для INSERT..SELECT

Вот именно, что везде и используется в движке одно поле с несколькими значениями.
Как обыграть? (Понятно что можно еще таблицу притулить и записывать туда отдельно значения, но, интересна данная ситуация)
А про таблицу связку не понял.. Хм
4. KingStar - 29 Января, 2014 - 10:39:08 - перейти к сообщению
если правильно понял

PHP:
скопировать код в буфер обмена
  1.     $users = explode('|', '|u1|u2|u225|');
  2.     foreach($users AS $row){
  3.          $db->query("INSERT...");
  4.     }
5. EuGen - 29 Января, 2014 - 10:41:41 - перейти к сообщению
Обыграть так:

Изменить
PHP:
скопировать код в буфер обмена
  1.  
  2. main_table
  3.  
  4. | one | id1,id4,id6 |
  5. | two | id8,id9,id3 |


На

PHP:
скопировать код в буфер обмена
  1. main_table
  2.  
  3. | one |
  4. | two |
  5.  
  6. secondary_table
  7.  
  8. | one | id1 |
  9. | one | id4 |
  10. | one | id6 |
  11. | two | id8 |
  12. | two | id9 |
  13. | two | id3 |


И распрощаться с jaywalker
6. KingStar - 29 Января, 2014 - 10:42:09 - перейти к сообщению
думаю еще следует проверять значения на пустоту

PHP:
скопировать код в буфер обмена
  1. if(!empty($row)) $db->query("INSERT...");

 

Powered by ExBB FM 1.0 RC1