Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: как посчитать сумму одного столбца таблицы по двум критериям?

Сообщения:  [1-10]    [11-20]  [21-21] 

 
 автор: cheops   (16.09.2009 в 01:15)   письмо автору
 
   для: Bvz   (16.09.2009 в 01:12)
 

Просто перечисляйте функции SUM() с соответствующими столбцами через запятую.

  Ответить  
 
 автор: Bvz   (16.09.2009 в 01:12)   письмо автору
 
   для: Саня   (15.09.2009 в 11:29)
 

а если надо посчитать несколько сум нескольких столбцов

  Ответить  
 
 автор: Bvz   (15.09.2009 в 12:01)   письмо автору
 
   для: Trianon   (15.09.2009 в 11:45)
 

еще раз спасибо!

  Ответить  
 
 автор: Trianon   (15.09.2009 в 11:45)   письмо автору
 
   для: Саня   (15.09.2009 в 11:29)
 

Это некорректное описание - в принципе.

# перечисляем данные, которые нужно выбрать
SELECT `master`.*, SUM(`visit`.`summa`) 

# из табличного выражения 
FROM   ( 
  # к таблице 
   `master`  
       # присоединяем данные из таблицы visit
     LEFT JOIN `visit`  
  # критерий присоединения - совпадение идентификаторов мастера из таблиц visit и master
        ON `visit`.`id_master`=`master`.`id`    
)
# за указанный день
WHERE `date`='".$day."'  

# группируем отдельно по каждому мастеру
GROUP BY `master`.`id`"


Скобки, добавленные мной, можно опустить. Суть от этого не изменится. В разделе FROM указывается табличное выражение (произвольной сложности), а не одна таблица.
LEFT JOIN является не отдельным разделом, а табличной операцией.

  Ответить  
 
 автор: Bvz   (15.09.2009 в 11:42)   письмо автору
 
   для: Саня   (15.09.2009 в 11:29)
 

спасибо!!!

  Ответить  
 
 автор: Саня   (15.09.2009 в 11:29)   письмо автору
 
   для: Bvz   (15.09.2009 в 10:38)
 

# перечисляем данные, которые нужно выбрать
SELECT `master`.*, SUM(`visit`.`summa`) 

# из таблицы master
FROM `master`  

# присоединяем данные из таблицы visit
LEFT JOIN `visit`  

  # критерий присоединения - совпадение идентификаторов мастера из таблиц visit и master
  ON `visit`.`id_master`=`master`.`id`  

# за указанный день
WHERE `date`='".$day."'  

# группируем отдельно по каждому мастеру
GROUP BY `master`.`id`"

  Ответить  
 
 автор: Trianon   (15.09.2009 в 11:19)   письмо автору
 
   для: heed   (14.09.2009 в 23:44)
 

>кстати ниже нормально предложено как заменить $fetch['SUM(`visit`.`summa`)'] напросто $fetch['summa']

Вот против этого не могу не возразить.
Делать алиас, совпадающий с именем существующего объекта - крайне неряшливо.
Во-первых, очень тяжело воспринимается человеком.
Во-вторых, могут возникнуть неоднозначности и побочные эфффекты, нарушающие планируемое поведение запроса.
Безусловно, отвлеченный алиас - только благо в подобной ситуации.

  Ответить  
 
 автор: Bvz   (15.09.2009 в 10:38)   письмо автору
 
   для: heed   (14.09.2009 в 23:44)
 

в целом спасибо, а вообще хотелось детально этот пример разобрать, чтоб потом не мучать форумчан подобными вопросами, поможите разобрать что и для чего?

  Ответить  
 
 автор: heed   (14.09.2009 в 23:44)   письмо автору
 
   для: Bvz   (14.09.2009 в 23:20)
 

Ну а чегоЖ)
если-бы там непонравилось что нули где-то в массивах получаются, а то вообще не понравилось что массивы получились

там в print_r() было всё показано , какие ключи у каких елементов.
Может нужно будет написать что-то вообще такое
<?
echo '<a href="delmaster.php?id='$fetch['id']
 .
'">Удалить мастера</a><br/>' ."\n"
 
.'а зовут его '$fetch['name']  .' и заработал он всего '
 
$fetch['SUM(`visit`.`summa`)'] ."<hr/>\n";
кстати ниже нормально предложено как заменить $fetch['SUM(`visit`.`summa`)'] напросто $fetch['summa']

  Ответить  
 
 автор: Bvz   (14.09.2009 в 23:20)   письмо автору
 
   для: heed   (14.09.2009 в 23:09)
 

чем дальше в лес, тем больше дров :)

  Ответить  

Сообщения:  [1-10]    [11-20]  [21-21] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования