Главная страница
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.026 c
14-41998
Song
2003-10-24 11:50
2003.11.13
Invalid System Disk, Insert Disk and Hit Enter


9-40761
Начинающий_программист
2003-05-05 11:47
2003.11.13
Послушайте!


3-40799
denmin
2003-10-22 13:56
2003.11.13
Помогите!!! Проблема с передачей параметров!


3-40813
Брат
2003-10-21 19:17
2003.11.13
SQL


4-42268
VaS
2003-09-05 09:07
2003.11.13
CreateProcess - странная пауза при ожидании