Главная страница
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.017 c
1-33207
Hawker2007
2003-07-29 13:02
2003.08.11
TreeView


14-33273
Soft
2003-07-23 19:28
2003.08.11
Настоящие программисты любят Windоws


1-33113
Bill
2003-07-29 18:23
2003.08.11
Загрузка данных из потока в TWebBrouser


3-33060
kalishenko
2003-07-18 13:29
2003.08.11
_qsql000.dbf - что это?


1-33216
Григорий Ситнин
2003-07-28 13:18
2003.08.11
Кнопки управления модальными окнами