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

Вниз

Как сделать аналог автоинкремнтоного поля в dbf   Найти похожие ветки 

 
Term ©   (2003-10-16 12:38) [0]

Как сделать аналог автоинкремнтоного поля в dbf


 
grusty   (2003-10-16 12:44) [1]

В DBF, наверное, никак. Но можно создать числовое поле и по единице прибавлять при добавлении записи...


 
Term ©   (2003-10-16 12:52) [2]

a использование GUID, можете дать примерчик


 
Term ©   (2003-10-16 13:26) [3]

ну ктонить.... посоветуйте как лучше отранизовать
а вот такой вариант
SELECT MAX(id) FROM Table
и потом полученное значение увеличивать на единицу и вставлять в поле, или это всё как то можно сделать по человечески, мне чтото другое в голову не приходит, посоветуйте......


 
Sandman25 ©   (2003-10-16 13:45) [4]

procedure TdmTables.qZakazUpdateError(DataSet: TDataSet; E: EDatabaseError;
UpdateKind: TUpdateKind; var UpdateAction: TUpdateAction);
begin
if (UpdateKind = ukInsert) and (Pos("Key violation", E.message) > 0) then
begin
qZakazId.NewValue := GetNewZakazId; // вызов функции для нахождения следующего;
UpdateAction := uaRetry;
end;
end;

function TdmTables.GetNewZakazId: integer;
begin
with qGetNewZakazId do
try
// SQL.Text = select max(id) from zakaz
Open;
Result := Fields[0].AsInteger + 1;
finally
Close;
end;
end;


 
Anatoly Podgoretsky ©   (2003-10-16 13:47) [5]

dBase VII есть автоинкриментные поля


 
Владислав ©   (2003-10-16 15:18) [6]

Где то читал пример такой. Создается таблица с одним полем и с одной записью (как раз счетчик). Чтобы получить его значение, блокируется таблица, берется значение счетчика, а потом в таблице инкрементируется, дальше разблокируется. (Блокировка необходима для многопользовательской системы).


 
Stas ©   (2003-10-16 16:08) [7]

Делаешь еще одну таблицу, в которой есть одно поле и будет всего одна запись-значение Автоинкремента.
На событие OnInsert считываешь оттуда значение, добавляешь 1 записываешь в свою таблицу и в ту где хранится это значение.



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

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

Наверх




Память: 0.48 MB
Время: 0.024 c
7-42148
SDW_syscoder
2003-09-03 11:05
2003.11.13
Работа с внешним девайсом через COM порт


3-41012
Павел
2003-10-16 08:19
2003.11.13
Проблема с QRMemo


6-41812
Demetrius
2003-09-15 14:15
2003.11.13
IP -> MAC и наоборот


3-40812
vantage10
2003-10-22 12:46
2003.11.13
перевод SQL запросов для работы с Access на MS SQL Server 2k


6-41830
Rus
2003-09-14 04:06
2003.11.13
Конференция