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

Вниз

Как составить запрс?   Найти похожие ветки 

 
vladimirS ©   (2003-02-14 09:48) [0]

имеется таблица:
CREATE TABLE REPL_LOG (
REGIONID integer,
SENDINGNO INTEGER);

в таблице находятся сл. данные (их на самом деле больше):
REGIONID SENDINGNO
1100 1
1100 2
1100 3
1100 4
1100 5
2200 1
2200 4
2200 6

В 2200 отсутствуют номера 2,3 и 5

Как составить запрос (не ХП!), который бы выводил недостающие номера и соответствующий regionID?


 
Johnmen ©   (2003-02-14 09:53) [1]

Запрос будет работать в многопользовательском варианте ?


 
vladimirS ©   (2003-02-14 09:55) [2]


> Запрос будет работать в многопользовательском варианте ?

нет


 
JibSkeart ©   (2003-02-14 10:37) [3]

можно попробовать Курсором ...
пробежать по REGIONID
и смотреть SENDINGNO

declare @SENDINGNO int,@REGIONID int,@i
SET @i = 0
SET NOCOUNT ON
declare test_cur cursor for select REGIONID,SENDINGNO from REPL_LOG order by REGIONID open test_cur
fetch next from test_cur into @REGIONID,@SENDINGNO
while (@@fetch_status <> -1)
begin
if (@@fetch_status <> -2)
begin
и сдесь делать сравнения
немного математики
end
fetch next from test_cur into @REGIONID,@SENDINGNO
end
close test_cur
deallocate test_cur


Ну это что первое в голову пришло ...
а что либо лутше придумать не смог
бошка трещит :((



 
Romkin ©   (2003-02-14 10:57) [4]

Ну-ну, вропрос-то по IB!!! :-)))
Я бы предложил создать вспомогательную таблицу с одним столбцом integer от 1 до N, N - максимальное число в SENDINGNO, можно по мере надобности триггером добавлять номера.
И потом запрос по двум таблицам, что-то вроде where not exists ...


 
perov ©   (2003-02-14 11:04) [5]

>есть таблица с полем cod integer, и знаем что в этом поле
>числа из определёного диапазона... как узнать цыфры которых
>нет ???

>Это придумал Бузаджи :
>-------------------------------------------------------------->select t.ID+1 ,Min(T1.ID)-1,Min(T1.ID)-t.ID-1 from
> TABLE1 T
>join TABLE1 T1 on T.id<T1.id
>where t.ID<=1000 and t1.ID<=1000
>group by t.ID
>having Min(T1.ID)-t.ID>1

>Получаем промежутки в которых удалены записи.
>В первой колонке будет начальный ID промежутка, во второй - >конечный.
>В третьей количество удаленных записей в промежутке.



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

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

Наверх




Память: 0.48 MB
Время: 0.025 c
1-5561
Nehto
2003-02-21 16:25
2003.03.03
Svoistvo color


14-5823
vell
2003-02-13 12:59
2003.03.03
Подскажите пожалуйста компоненты для


7-5886
FoxM
2003-01-04 12:49
2003.03.03
res - файл


4-5916
bkv
2003-01-16 13:04
2003.03.03
Текущее положение мыши в Delphi3


3-5385
qwerty2
2003-02-12 11:00
2003.03.03
Hint DBNavigator a