Модераторы: Akina
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Запрос с ограничением 
:(
    Опции темы
Yulaw
Дата 9.9.2010, 14:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 15
Регистрация: 7.2.2010

Репутация: нет
Всего: нет



Здравствуйте! Помогите пожалуйста с запросом: Нужно сделать запрос выводящий список значений чья сумма по одному из полей не превышает определенное число. Пример:
таблица 1
поле 1; поле 2;       поле 3;
1           красный       20
2           зеленый       30
3           желтый        10
4           черный         10

после запроса с условием <= 50 по 3-му полю, выводит:
поле 1; поле 2;       поле 3;
1           красный       20
2           зеленый       30

сумма значений 3-го поля 50, что соответствует условию. 
 
Думал долго, но так и не осинило как  это сделать... прошу помощи у знатоков. 
PM MAIL   Вверх
azesmcar
Дата 9.9.2010, 14:36 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


uploading...
****


Профиль
Группа: Участник Клуба
Сообщений: 6291
Регистрация: 12.11.2004
Где: Армения

Репутация: нет
Всего: 211



тебе кажется сюда
http://forum.vingrad.ru/forum/topic-307961.html
 smile 

PM   Вверх
Yulaw
Дата 9.9.2010, 14:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 15
Регистрация: 7.2.2010

Репутация: нет
Всего: нет



Ничего полезно я там не нашел... Нужно это написать только средствами SQL Servera без написания сторонних приложений.
PM MAIL   Вверх
aleksh
Дата 9.9.2010, 15:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 609
Регистрация: 8.7.2008

Репутация: 1
Всего: 13



это для чего такие задачки?
PM MAIL   Вверх
Zloxa
Дата 9.9.2010, 16:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 10
Всего: 161



Цитата(Yulaw @  9.9.2010,  14:34 Найти цитируемый пост)
после запроса с условием <= 50 по 3-му полю, выводит:
поле 1; поле 2;       поле 3;
1           красный       20
2           зеленый       30

подумайте, почему именно так, как вы показали а не к примеру так:
2           зеленый       30
3           желтый        10
4           черный         10
а вообще:
Код

select * from (select t.*,sum(поле3) over (order by поле1) sm from таблица t) where sm <= 50


Добавлено @ 16:29
блин, отменяется.... они даже в 2008р2 так и не реализовали накапливающую сумму.
тогда по старинке
Код

select * from таблица t where (select sum(поле3) from таблица s where s.Поле1<=t.Поле1)<=50

соответственно это решение, в отличи от предыдущего не полномиально, я теперь знаю это умное слово.

Это сообщение отредактировал(а) Zloxa - 9.9.2010, 16:31


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Yulaw
Дата 10.9.2010, 09:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 15
Регистрация: 7.2.2010

Репутация: нет
Всего: нет



Спасибо, считать, считает, но работает жутко медленно при большом количестве значений

Это сообщение отредактировал(а) Yulaw - 10.9.2010, 09:59
PM MAIL   Вверх
Zloxa
Дата 10.9.2010, 10:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 10
Всего: 161



Yulaw, да, и количество затрат будет расти по экспоненте к количеству данных, подлежащих обработке.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Yulaw
Дата 10.9.2010, 10:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 15
Регистрация: 7.2.2010

Репутация: нет
Всего: нет



А есть еще какие нибудь альтернативы возможные при использование только возможностей sql servera (2008)? Или все таки лучше будет написать стороннюю программу  выполняющую эту функцию и выгружающую результат во временную таблицу?
PM MAIL   Вверх
Zloxa
Дата 10.9.2010, 10:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 10
Всего: 161



Цитата(Yulaw @  10.9.2010,  10:37 Найти цитируемый пост)
Или все таки лучше будет написать стороннюю программу  выполняющую эту функцию и выгружающую результат во временную таблицу? 

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

Добавлено через 1 минуту и 15 секунд
пардон... увидел.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "MS SQL"
Akina

Akina

Запрещается!

Публиковать ссылки и обсуждать взлом чего бы то ни было.

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы составления неспецифических запросов рассматриваются здесь
  • Используйте теги [code=sql][/code] для подсветки кода. Используйтe чекбокс "транслит" (возле кнопок кодов) если у Вас нет русских шрифтов.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, Akina.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MS SQL Server | Следующая тема »


 




[ Время генерации скрипта: 0.1179 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.