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

Сложение числовых значений в строках

22.09.2016, 12:06. Показов 8188. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Вот результат запроса:
C0 | C1 | C2
8,4 | 8,4 | 25,6
8,6 | 8,1 | 26,3

Результат запроса всегда две строки. Случилось так что необходимо сложить значения в колонке С0, С2, С3 и результат выдать ниже
Пример:
C0 | C1 | C2
8,4 | 8,4 | 25,6
8,6 | 8,1 | 26,3
17 | 16,5| 51,9

Если есть у кого решения то не могли бы поделится? Спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.09.2016, 12:06
Ответы с готовыми решениями:

Сортировка числовых значений
Возможно сделать сортировку по полю с типом данных varchar, если данные только числа? То бишь так: 1 2 3 4 5 22 45 58

Замена значений в столбце во всех строках таблицы
Сейчас в таблице много пустых значений. Мне требуется в полях поставить "0". В "Management Studio" делаю select и вижу...

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

8
Zero day
 Аватар для Meridian21
267 / 231 / 78
Регистрация: 16.12.2015
Сообщений: 943
Записей в блоге: 4
22.09.2016, 14:01
Ale_x, тебе надо сделать конструкцию следующего вида:
SQL
1
2
SELECT SUM(qq) AS C0, SUM(qw) AS C1, SUM(qe) AS C2 FROM
(SELECT C0 AS qq, C1 AS qw, C2 AS qe FROM <оставшаяся часть твоего запроса, который выводит две строки>)
1
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
22.09.2016, 14:32
Лучший ответ Сообщение было отмечено Ale_x как решение

Решение

T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
with s as
(
 /*Доработанный запрос, возвращающий две строки*/
 select
  c0, c1, c2,
  row_number() over (order by (select 1)) as rn
 from
  ...
)
select
 sum(c0), sum(c1), sum(c2)
from
 s
group by
 grouping sets((c0, c1, c2, rn), ());
1
119 / 111 / 47
Регистрация: 09.07.2013
Сообщений: 209
22.09.2016, 14:56
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
with s as
(
 /*Доработанный запрос, возвращающий две строки*/
 select
  c0, c1, c2
 from
  ...
)
select
 sum(c0), sum(c1), sum(c2)
from
 s
group by
 grouping sets((c0, c1, c2), ());
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
22.09.2016, 15:05
Serpentariy, а если c0, c1, c2 совпадут в разных строках?
0
119 / 111 / 47
Регистрация: 09.07.2013
Сообщений: 209
22.09.2016, 15:11
Таки да. Вы правы.
0
7 / 1 / 0
Регистрация: 12.05.2015
Сообщений: 17
23.09.2016, 07:59  [ТС]
invm - Спасибо большое все сработало!

Добавлено через 1 час 51 минуту
Извиняюсь, скажите а если нужно сделать вычитание?
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
23.09.2016, 11:23
Лучший ответ Сообщение было отмечено Ale_x как решение

Решение

Цитата Сообщение от Ale_x Посмотреть сообщение
а если нужно сделать вычитание?
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
with s as
(
 /*Доработанный запрос, возвращающий две строки*/
 select
  c0, c1, c2,
  row_number() over (order by (select 1)) as rn
 from
  ...
)
select
 sum(case when rn = 1 then c0 else -c0 end), sum(case when rn = 1 then c1 else -c1 end), sum(case when rn = 1 then c2 else -c2 end)
from
 s
group by
 grouping sets((c0, c1, c2, rn), ());
1
7 / 1 / 0
Регистрация: 12.05.2015
Сообщений: 17
23.09.2016, 11:51  [ТС]
Цитата Сообщение от invm Посмотреть сообщение
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
with s as
(
 /*Доработанный запрос, возвращающий две строки*/
 select
  c0, c1, c2,
  row_number() over (order by (select 1)) as rn
 from
  ...
)
select
 sum(case when rn = 1 then c0 else -c0 end), sum(case when rn = 1 then c1 else -c1 end), sum(case when rn = 1 then c2 else -c2 end)
from
 s
group by
 grouping sets((c0, c1, c2, rn), ());
Спасибо, работает. Жаль что значения в результате запроса со знаком - "минус"
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.09.2016, 11:51
Помогаю со студенческими работами здесь

Сложение числовых значений одинаковых элементов массива
У меня такая проблема: дан следующий список слов в файле: словосочетание из двух слов, год, первое число, второе число. Это выглядит вот...

В числовых строках в вертикальных столбцах удалить строки по условию
Подскажите как в числовых строках в вертикальных столбцах Удалить строки по условию: Есть массив чисел 4 14 15 20 36 7 9 18 28 38 ...

Структура: подсчет максимальных и минимальных значений, сумм и средних значений для числовых полей
Структура должна включать не менее 10 столбцов, в том числе – строковые, числовые и дата, всего в таблице должно быть не менее 30 строк. ...

Сложение длинных чисел, содержащихся в строках
Даны две строки, которые содержат только цифры (длина каждой более 10 символов). Считая, что эти ленты содержат очень большие целые числа,...

Группировка и сложение значений двумерного массива по совпадению двух значений
Всем добрый день! Голову сломал, смиренно прошу помощи. Есть двумерный массив, задача: объединить (сгруппировать) элементы при...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru