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

Вниз

Физический номер записи   Найти похожие ветки 

 
pavelsinicinV   (2002-11-07 19:22) [0]

Как через SQl определить физический номер записи таблицы ?
Подобная функция имеется для таблиц DBase RECNO()...


 
Ihor Osov'yak ©   (2002-11-07 19:41) [1]

Уважаемый Павел.

Если мне изменяет память, Вам уже примерно неделю назад обьясняли, что делать ориентировку на физический номер записи в реляционных базах не следует. Причем и в доходчивой форме, и несколько в резкой.

Конспективно повторюсь:

1. Большинство релационных баз, работающих по технологии клиент-сервер, не поддерживают такого понятия. То есть соотв. фунции нет.

2. Если Вам все же нужен аналог номера записи - сделайте уникальный ключ (индекс) по полю, значение которого монотоно возрастает. Самый простой способ - автоинкрементное (кстати, его поддерживают не все движки). На основании этого ключа просто написать вычисляемое поле в представлении, запросе, етс, которое будет показывать номер записи, но в общем случае это не будет эквивалетн понятию "номер физической записи".

3. Если у Вас все же есть необходимость знать физический номер записи, то у Вас либо неправильно спроектированна структура базы, либо Вы редкий ...


ЗЫ. Растолкуйте внятно, зачем Вам это нужно.






 
MsGuns ©   (2002-11-07 20:55) [2]

RecNo() возвращает не ФИЗИЧЕСКИЙ номер записи в БД, а ПОРЯДКОВЫЙ номер полученного курсора (подмножества сущностей БД)


 
MsGuns ©   (2002-11-07 21:07) [3]

Пардон, между "номер" и "полученного" следует читать еще "строки/записи"

PS Если ПОРЯДКОВЫЙ номер записи в НД Вам нужен для того, чтобы ориентироваться относительно начала и конца НД (типа запись 456 из 9074), а формат БД не поддерживает RecNo(), Вам необходимо в запросе формировать одно искусственное поле (посредством, например, CAST(MIN|MAX(Goods_Kol) AS INTEGER) as "NPP"), а потом в цикле

i:=1; q.First;
While Not q.Eof do begin
q.FieldByName("NPP").AsInteger := i;
inc(i);
q.Next;
end;
q.First; // Вернуться в начало строки

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





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

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

Наверх




Память: 0.47 MB
Время: 0.025 c
3-82613
Ryser
2002-11-05 13:37
2002.11.25
Как обновить TQuery не потеряв при этом текущей записи


1-82723
Maksss
2002-11-14 22:32
2002.11.25
Нужен исходняк JPEG.PAS из Delphi6 .


1-82750
Leny
2002-11-13 14:13
2002.11.25
Удаление процесса


3-82625
Свой
2002-11-04 21:38
2002.11.25
File in Paradox


14-82971
nick_vstu
2002-11-05 10:32
2002.11.25
Вам нравится група Ленинград?