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 :: Статистика?

 PHP.SU

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


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

> Без описания
greenzlat
Отправлено: 04 Марта, 2009 - 18:17:06
Post Id


Новичок


Покинул форум
Сообщений всего: 59
Дата рег-ции: Апр. 2008  


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




Есть 2 таблицы! Нужно подсчитать кол-во строк в одной и записать их в другую!
Делаю вот так:

CODE (text):
скопировать код в буфер обмена
  1. <? $result12 = mysql_query("SELECT COUNT(*) FROM table ");
  2. $myrow12 = mysql_fetch_array ($result12);
  3. $update = mysql_query ("UPDATE options SET pole='$myrow12'",$db);?>



Он не ставит в поле POLE ничего, то есть остается 0!
Что я не так делаю??
 
 Top
Ch_chov
Отправлено: 04 Марта, 2009 - 19:16:25
Post Id



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


Покинул форум
Сообщений всего: 2121
Дата рег-ции: Июль 2008  
Откуда: из города


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




mysql_fetch_array всегда возвращает массив
т.е. ты пытаешся вставить в таблицу массив
 
 Top
valenok Модератор
Отправлено: 04 Марта, 2009 - 21:33:08
Post Id



Здесь могла бы быть ваша реклама


Покинул форум
Сообщений всего: 4574
Дата рег-ции: Июль 2006  
Откуда: Israel


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




UPDATE `options` SET `pole`= (SELECT COUNT(`id`) FROM `table` )


-----
Truly yours, Sasha.
 
My status
 Top
Gordey
Отправлено: 04 Марта, 2009 - 21:57:59
Post Id


Новичок


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


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




Можно сделать проще, составив вложенный запрос:

PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3.  
  4. $result = mysql_query("UPDATE options SET pole = (SELECT COUNT(*) FROM table)");
  5.  
  6. ?>
  7.  

Только тут нужо быть внимательным, все зависит от структуры таблицы options. При запросе который приведен выше все строки поле pole примут значение равное кол-ву строк в таблице table.
Что бы этого избежать достаточно указать условие, например:
PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3.  
  4. $result = mysql_query("UPDATE options SET pole = (SELECT COUNT(*) FROM table) WHERE options.date = '20090304'");
  5. ?>
  6.  

Этот запрос обновит только, то поле pole, которому соответствует сегодняшняя дата 2009-03-04. Т.е. кол-во посетителей за сегодня.
Все будет зависить от структуры вашей таблицы options! Будьте внимательны.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB