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 :: Подстчет количества строк в запросе SELECT

 PHP.SU

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


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

> Без описания
UNTRUSTED
Отправлено: 14 Марта, 2012 - 05:56:23
Post Id


Частый гость


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


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




Долго уже мучает вопрос каким образом лучше подсчитывать количество строк в запросе!!
Есть несколько вариантов, подскажите какой лучше?? Сортирую по моему мнению в порядке улучшения запроса!!!
PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3. //1 вариант
  4. $col = mysql_query("SELECT id FROM users");
  5. echo mysql_num_rows($col);
  6. //2 вариант
  7. $col = mysql_query("SELECT COUNT(id) FROM users");
  8. /*2.1*/
  9. echo mysql_result($col,0);
  10. /*2.2*/
  11. $a mysql_fetch_array($col,MYSQL_NUM);
  12. echo $a[0];
  13. /*2.3*/
  14. $b = mysql_fetch_row($col);
  15. echo $b[0];
  16. ?>
  17.  

Ну вот вообщем вроде все!! Как думаете, какой лучше использовать?? Или есть другие варианты???
Еще вот на такой вариант наткнулся!!!
PHP:
скопировать код в буфер обмена
  1.  
  2. //в базе 15 юзеров
  3. mysql_query("SELECT SQL_CALC_FOUND_ROWS id FROM users LIMIT 1");
  4. echo(mysql_result(mysql_query("SELECT FOUND_ROWS()"),0)); //выводит правильный результат = 15!
  5.  

(Отредактировано автором: 14 Марта, 2012 - 06:37:24)

 
 Top
EuGen Администратор
Отправлено: 14 Марта, 2012 - 08:07:24
Post Id


Профессионал


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


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




SELECT COUNT(1) FROM users
(в ряде случаев оно эквивалентно SELECT COUNT(*))


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
UNTRUSTED
Отправлено: 14 Марта, 2012 - 08:09:20
Post Id


Частый гость


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


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




А в таком случае все-таки каким лучше пользоваться?? 2.1 || 2.2 || 2.3 ?? И что про 3й вариант скажете??
 
 Top
EuGen Администратор
Отправлено: 14 Марта, 2012 - 08:11:46
Post Id


Профессионал


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


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




Я написал Вам оптимальный вариант. Для оценки всех вариантов Вы можете использовать EXPLAIN


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
UNTRUSTED
Отправлено: 14 Марта, 2012 - 08:14:11
Post Id


Частый гость


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


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




запрос то понятно!! Я же теперь про вывод данных из этого запроса спросил!!
 
 Top
snikers987
Отправлено: 14 Марта, 2012 - 08:34:24
Post Id



Участник


Покинул форум
Сообщений всего: 1239
Дата рег-ции: Сент. 2011  
Откуда: Крым


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




UNTRUSTED советую вообще забыть, что есть такая функция как mysql_result().


-----
Когда всматриваешься в тёмную бездну, учти, что кто-то может смотреть на тебя из неё...
 
My status
 Top
UNTRUSTED
Отправлено: 14 Марта, 2012 - 09:04:19
Post Id


Частый гость


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


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




ну да!! Я слышал что она тормознутая и много проблем с нейУлыбка Плюс у ней единственный что код можно сократить хорошо!!

(Отредактировано автором: 14 Марта, 2012 - 09:06:22)

 
 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