Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/88: Рейтинг темы: голосов - 88, средняя оценка - 4.92
0 / 0 / 1
Регистрация: 19.12.2012
Сообщений: 177

Запрос на суммирование определеных полей

04.03.2017, 17:51. Показов 17973. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Приветствую всех .Честно говоря не знаю в тот раздел ли написал если что извиняюсь

подскажите как выполнить такой запрос

Есть таблицу с двух полей
Колонка 1 | Колонка 2|
Поле 1| 200 |
Поле 2| 100 |
Поле 1| 100 |
Поле 3| 120 |

И в результате получилось

Поле 1 | 300
Поле 2 | 100
Поле 3 | 120

То есть поля объединялись и суммировались
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.03.2017, 17:51
Ответы с готовыми решениями:

Запрос на суммирование двух полей и вычитание третьего
Добрый день! Подскажите как такой запрос реализовывается: Имеется таблица Main, у нее поле id уникально, есть три таблицы у которых поле...

суммирование 2ух полей.ЗАПРОС
ребят вот смотрите есть 2 поля русский и математика из таблицы оценки, как создать новое поле с суммой 2ух оценок к каждому студенту. ...

Запрос на суммирование логических полей в БД
Добрый день. Возникла следующая проблема: БД содержит в формах и таблицах много переключателей (флажков) для вывода отчета нужно их...

13
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
04.03.2017, 20:58
это называется группировкой

SQL
1
SELECT [Колонка 1], SUM([Колонка 2]) FROM [Таблица 1] GROUP BY [Колонка 1]
1
0 / 0 / 1
Регистрация: 19.12.2012
Сообщений: 177
05.03.2017, 08:51  [ТС]
Благодарю а можете помочь если не затруднит

Хочу что бы не суммировались значения больше 100
А которые меньше в другое поле
А также их количество

И в результате получилось

Поле 1 | 300 | сумма значений <100 |Кол-во>100|Кол-во<100
Поле 2 | 100 | сумма значений <100 |Кол-во>100|Кол-во<100
Поле 3 | 120 | сумма значений <100 |Кол-во>100|Кол-во<100

Тут попробовал отсеить по значению меньше 100 но если одно поле >100 тогда оно суммирует даже меньшие числа.
SQL
1
2
3
4
SELECT Таблица1.Колонка1, SUM(Таблица1.Колонка2) AS [Sum-Колонка2]
FROM Таблица1
GROUP BY Таблица1.Колонка1
HAVING (((SUM(Таблица1.Колонка2))>=100));
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
05.03.2017, 09:01
Цитата Сообщение от Zorroo Посмотреть сообщение
Кол-во>100|Кол-во<100
а те что точно ровны 100, не считаем вообще?

T-SQL
1
2
3
4
5
6
7
8
SELECT 
  Колонка1,  
  SUM(Колонка2), 
  SUM(CASE WHEN Колонка2 < 100 THEN Колонка2 ELSE 0 END),
  COUNT(CASE WHEN Колонка2 > 100 THEN 1 ELSE 0 END),
  COUNT(CASE WHEN Колонка2 < 100 THEN 1 ELSE 0 END)
FROM Таблица1
GROUP BY Колонка1
1
0 / 0 / 1
Регистрация: 19.12.2012
Сообщений: 177
05.03.2017, 09:39  [ТС]
Благодарю ,правда там на 3-ей строчки ошибка синтаксиса можете посмотреть .Я не могу разобрать где там ошибка
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
05.03.2017, 09:55
да нет, запрос работает.
как именно ругается?
Миниатюры
Запрос на суммирование определеных полей  
1
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
05.03.2017, 09:56
Может при переписывании где ошиблись? Приведите ваш вариант
1
0 / 0 / 1
Регистрация: 19.12.2012
Сообщений: 177
05.03.2017, 10:06  [ТС]
Вот такая ошибка ,вроде все правильно переписал
Миниатюры
Запрос на суммирование определеных полей  
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
05.03.2017, 10:15
А почему MS Access? эта ветка про SQL Server.

Добавлено через 3 минуты
Тогда вместо
T-SQL
1
CASE WHEN Колонка2 < 100 THEN Колонка2 ELSE 0 END
надо писать что-то вроде
SQL
1
IIF(Колонка2 < 100; Колонка2; 0)
1
0 / 0 / 1
Регистрация: 19.12.2012
Сообщений: 177
05.03.2017, 10:31  [ТС]
Я чуял что не в тот раздел попал

Спасибо но я явно не понимаю как это выполнить
SQL
1
2
3
4
5
6
7
SELECT 
  Колонка1,  
  SUM(Колонка2), 
  COUNT((IF( Колонка2 > 100;Колонка2:1))),
  COUNT((IF( Колонка2 < 100;Колонка2:0)))
FROM Таблица1
GROUP BY Колонка1
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
05.03.2017, 10:55
SQL
1
2
3
4
5
6
7
8
SELECT 
  Таблица1.Колонка1, 
  SUM(Таблица1.Колонка2) AS [Sum-Колонка2], 
  SUM(IIf([Колонка2]<100,[Колонка2],0)) AS SUM100G, 
  SUM(IIf([Колонка2]>100,1,0)) AS Cnt100G, 
  SUM(IIf([Колонка2]<100,1,0)) AS Cnt100L
FROM Таблица1
GROUP BY Таблица1.Колонка1;
1
0 / 0 / 1
Регистрация: 19.12.2012
Сообщений: 177
05.03.2017, 11:08  [ТС]
Благодарю вас! Очень помогли.
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
05.03.2017, 17:53
Цитата Сообщение от YuryK Посмотреть сообщение
а те что точно ровны 100, не считаем вообще?

T-SQL
1
2
3
4
5
6
7
8
SELECT 
  Колонка1,  
  SUM(Колонка2), 
  SUM(CASE WHEN Колонка2 < 100 THEN Колонка2 ELSE 0 END),
  COUNT(CASE WHEN Колонка2 > 100 THEN 1 ELSE 0 END),
  COUNT(CASE WHEN Колонка2 < 100 THEN 1 ELSE 0 END)
FROM Таблица1
GROUP BY Колонка1
А COUNTу не всё равно какие строки считать -
для которых внутренне выражение возвращает 1 или для которых возвращает 0?
Надо там COUNT заменить на SUM
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
05.03.2017, 17:56
уже заменено, прямо перед вашим сообщением
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.03.2017, 17:56
Помогаю со студенческими работами здесь

Суммирование полей через запрос на обновление
В MS Access создал базу для &quot;Товароведа магазина&quot;. Сейчас нужно в запросе на обновление написать процесс добавления в...

Помесячное суммирование полей и ввод значения в запрос из выпадающего списка
Нужно создать запрос, в котором для каждого месяца заданного года указывалась бы общая стоимость продаж в заданную страну в этом месяце. ...

Суммирование полей
Казалось бы самое элементарное, но никак не могу понять что нужно сделать. Нужно сложить два числа взятых из одного поля и второго и...

Суммирование полей
Добрый день! Подскажите пожалуйста, есть таблица Conve в ней поля id, date, den1, den2, den3 ,..., den31, itog Как посчитать сумму...

Суммирование вычисляемых полей.
На ленточной форме есть вычисляемые поля, при изменении значения одного из полей все поля должны просумироваться. При написании...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru