Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.08.11;
Скачать: CL | DM;

Вниз

Выборка из IBase   Найти похожие ветки 

 
S@shka ©   (2003-07-18 12:13) [0]

Народ вот как задачка
есть сервер БД c табличкой (TEST) напоненной приблизительно следующим
CODE VALUE
---------------
1 AAAA
2 ABCD
3 CCCC
и так далее
Задача. Необходимо подсчитать количество вхождения букв А в первой позиции, букв В в первой позиции и т.д.
Осложняется задача тем, что в первой позиции может быть 3 варианта (т.е. от А до С), вот второй, например 4 (то есть А..D) и т.д. но все это известно естественно.
Пока что энто делается из приложения клиент путем посылки запросов вида
select count (CODE) from TEST where VALUE LIKE "A___"
select count (CODE) from TEST where VALUE LIKE "B___"
select count (CODE) from TEST where VALUE LIKE "_A__"
и т.д.
естественно это гонять столько запросов по сети не рационально. Думаю возможно было бы написать хранимую процедуру на серваке, чтобы она возвращала сразу необходимый массив (ну или строку).
Если кто то сталкивался с подобным прошу помосчи. заранее спасибо.


 
Zacho ©   (2003-07-18 12:22) [1]

В IB6 и выше (а так же в FB и Yaffil) есть функция SUBSTRING ( FIELD_OR_VARIABLE FROM POSITION FOR LENGTH) В более ранних версиях можно использовать UDF


 
ЮЮ ©   (2003-07-18 12:23) [2]

1) Подсчитать все на клиенте, пройдя по таблице 1 раз
2) Если Value как совокупность символов смысла не имеет, то переделать структуру (Position, Simbol)


 
S@shka ©   (2003-07-18 12:33) [3]

VALUE имеет смысл имеенно как совокупность символов.
Зачем сваливать задачу подсчета на клиента - на фига тогда все преймущества select count()
это мне придется все качнуть и самому писать прогу обработки
Я думаю надо создать процедуру на серваке вот только думаю как??
изначально есть поле ААА в котором запись вида 2342
это значит что всего позиции
1 A..B
2 A..C
3 A..D
4 A..B
на до бы все посчитать и отпавить например строкой


 
Johnmen ©   (2003-07-18 12:34) [4]

Хранимая процедура с одним единственных проходом.


 
S@shka ©   (2003-07-18 12:40) [5]

Как хотя бы примерно????


 
ЮЮ ©   (2003-07-18 12:41) [6]

преймущества select count() тогда и преимущества, когда работают с полями. Т.е. со структурой (Position, Simbol) ты и получил бы одним запросом
SELECT Simbol, Position, Count(ID)
GROUP BY Simbol, Position




 
Smashich ©   (2003-07-18 12:41) [7]

берешь строку и парсишь. увеличиваешь счетчик соотвесвующий. следующая запись


 
Johnmen ©   (2003-07-18 12:46) [8]

>S@shka © (18.07.03 12:40)
>Как хотя бы примерно????

Примерно что ? Синтаксис ? Идею ?




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

Текущий архив: 2003.08.11;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.011 c
11-33086
_Ed_
2002-12-06 21:51
2003.08.11
Form.OnLeave(...)


14-33354
Ткаченко Сергей
2003-07-16 11:35
2003.08.11
Не обновляется SQL запрос


4-33388
Серега
2003-06-08 16:57
2003.08.11
Несколько файлов в один


14-33299
Viktor Kushnir
2003-07-24 07:45
2003.08.11
Алгоритм


6-33240
LOX
2003-06-04 11:48
2003.08.11
TEmbeddedWB ставится в D7