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]   

> Без описания
winchester007
Отправлено: 21 Апреля, 2014 - 14:08:51
Post Id


Новичок


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


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




Привет. Проблема вот в чем. Есть база:
|id|number|Point|
|1|1--------|10---|
|2|2--------|5-----|
|3|1--------|10---|
|4|2--------|5-----|
|5|1--------|10---|
|6|2--------|5-----|
---------------------
так вот, нада чтоб вытаскивало только одну строку с number = 1 и одну с number =2 . и сумувало их point.

(Отредактировано автором: 21 Апреля, 2014 - 14:13:11)

 
 Top
Stierus Супермодератор
Отправлено: 21 Апреля, 2014 - 14:29:26
Post Id



Рекордсмен по количеству сообщений за 7 дней


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


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




самое простое - через подзапрос

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT sum(point)
  2. FROM t2 WHERE id IN (
  3.         SELECT
  4.                 min(id)
  5.         FROM `t2`
  6.         GROUP BY `number`      
  7.         HAVING `number` IN (1, 2)
  8. )


Если таблицы большие и это медленно работает - пши ниже, посмотрим
 
My status
 Top
winchester007
Отправлено: 21 Апреля, 2014 - 14:33:58
Post Id


Новичок


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


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




Stierus пишет:
самое простое - через подзапрос

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT sum(point)
  2. FROM t2 WHERE id IN (
  3.         SELECT
  4.                 min(id)
  5.         FROM `t2`
  6.         GROUP BY `number`      
  7.         HAVING `number` IN (1, 2)
  8. )


Если таблицы большие и это медленно работает - пши ниже, посмотрим

да таблицы большые. А если сначала выбрать все, запхнуть значения намбера в масив, удалить одинаковые значения а потом ещо вытащить поинты с теми значениям и просумировать?
 
 Top
Zuldek
Отправлено: 21 Апреля, 2014 - 15:06:15
Post Id


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


Покинул форум
Сообщений всего: 2122
Дата рег-ции: Июнь 2010  


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




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT `number`, SUM(`Point`) AS points
  2. FROM `tbl_name`
  3. WHERE `number` IN (1, 2)
  4. GROUP BY `number`

?

(Отредактировано автором: 21 Апреля, 2014 - 15:07:37)

 
 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