Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2004.12.26;
Скачать: [xml.tar.bz2];

Вниз

Запрос   Найти похожие ветки 

 
GanibalLector ©   (2004-11-23 01:43) [0]

Есть такие поля : kol,type
Необходимо summ(kol) where type>1 !!!минус!!! summ(kol) where type=0
Типа как?Что-то немогу понять...


 
GanibalLector ©   (2004-11-23 01:44) [1]

В ХП могу,но хотель бы без


 
GanibalLector ©   (2004-11-23 01:50) [2]

Ёпрс...пардоньте за ошибки!
sum и хотел

З.Ы. Пока трезв


 
Deniz ©   (2004-11-23 08:15) [3]

Как должно быть показано?
select distinct
(select sum(kol) from table where type >= 1) as sum_1,
(select -sum(kol) from table where type = 0) as sum_0
from table
В firebird есть case


 
GanibalLector ©   (2004-11-23 09:35) [4]

2 Deniz
> как должно быть показано?
Одним числом.[3] пожет два


 
stud ©   (2004-11-23 10:25) [5]

условия по агрегатным функциям вроде having надо использовать


 
Deniz ©   (2004-11-24 06:55) [6]


> GanibalLector ©   (23.11.04 09:35) [4]
> 2 Deniz
> > как должно быть показано?
> Одним числом.[3] пожет два

Я балдею, а запятую после sum_1 убрать и чуть-чуть подправить не судьба?
select distinct
(select sum(kol) from table where type >= 1) -
(select sum(kol) from table where type = 0) as sum_0
from table


 
Sandman25 ©   (2004-11-24 09:58) [7]

[6] Deniz ©   (24.11.04 06:55)

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


 
Vemer ©   (2004-11-24 10:02) [8]

Вот:
Select Sum(kol * ((Type*2)-1) from table

А еще проще поменять 0 на -1 в таблице.


 
Johnmen ©   (2004-11-24 10:06) [9]

>Vemer ©   (24.11.04 10:02) [8]

А на что поменять type, больший 1 ?
:)


 
Vemer ©   (2004-11-24 10:21) [10]

To JohnMen
Пример и предложение по замене - под конкретную задачу, и др. данных нет )). Обычно "тип" имеет значения (-1 и 1, иногда 0 (нейтральная операция)).


 
Johnmen ©   (2004-11-24 10:24) [11]

>Vemer ©   (24.11.04 10:21) [10]

Да нормальный пример. Только типов может быть, и как правило бывает, больше 2/3.


 
Sandman25 ©   (2004-11-24 10:24) [12]

>А на что поменять type, больший 1 ?

Написать UDF типа sign?


 
Vemer ©   (2004-11-24 10:32) [13]

Структуру таблиц думать надо, чтобы потом данные из них просто  выковыривались. С точки зрения "типа" операции могут быть (-1, 1 и 0) а по "статусу" - сколько угодно (поставка, продажа, заказ, кредит, изменение пая, использование на фирме и т.д. и т.п.). Но все "статусы" вписываются в 3 "типа" .


 
Johnmen ©   (2004-11-24 10:39) [14]

>Sandman25 ©   (24.11.04 10:24) [12]
>Написать UDF типа sign?

Знак можно выделить и без исп-ия УДФ.

>Vemer ©   (24.11.04 10:32) [13]

Я имел в виду широкое понятие "тип". Напр. порода собак.


 
Sandman25 ©   (2004-11-24 10:45) [15]

[14] Johnmen ©   (24.11.04 10:39)

Если есть CASE или IIF? Или преобразованием в CHAR и анализом первого символа?


 
Johnmen ©   (2004-11-24 10:47) [16]

>Sandman25 ©   (24.11.04 10:45) [15]

Нет. Используя CAST к целому.


 
Sandman25 ©   (2004-11-24 10:54) [17]

[16] Johnmen ©   (24.11.04 10:47)

А если у нас уже целое?
Как из -3 сделать -1?


 
Johnmen ©   (2004-11-24 11:08) [18]

>Sandman25 ©   (24.11.04 10:54) [17]

Выделение знака (sign) для целочисленного типа поля:
SELECT
CAST(CAST(integerfield-0.5 AS INT)+1.5 AS INT)-1-integerfield
FROM ...


 
Sandman25 ©   (2004-11-24 11:14) [19]

[18] Johnmen ©   (24.11.04 11:08)

Красиво. Спасибо, запомню идею :)



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2004.12.26;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.48 MB
Время: 0.036 c
14-1102488330
WondeRu
2004-12-08 09:45
2004.12.26
Опрос: Иностранные языки


1-1103014114
Delphi5.01
2004-12-14 11:48
2004.12.26
выезжающее окошко как это сделано в WinAmp-е


4-1100029238
redlord
2004-11-09 22:40
2004.12.26
размер кластера HDD


1-1102669756
korvin
2004-12-10 12:09
2004.12.26
Форма не держится "сверху"


14-1102182152
ArMellon
2004-12-04 20:42
2004.12.26
У меня стоит Apache , как виртуальным хостам





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский