Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Delphi: Базы данных и репортинг > Создание автоинкрементного поля SQL запросом?


Автор: Poseidon 18.5.2005, 14:49
Код

  Lets say that we wish to create a fallawing number (Autoincrese) of an item, 
  without using the AutoIncrese filed. 
  This is usfull when for example there is more users from the same IP that log 
  in or any other things that you wish. 

  This example will show you how to do it with some checking of filled data, 
  but it can be done anyway you wish. 

  You need a Table with at least 2 fileds with number casting, and a TQUERY component. 



function TForm1.GetNextNumber : integer; 
begin 
 qryMain.Active := False; 
 qryMain.SQL.Clear; 
 qryMain.SQL.Add('Select Max(FieldToIncrease) from tblMain where (Cheking >=1);'); 
 qryMain.Active := True; //We executed the query 

 if qryMain.RecordCount >= 0 then 
  result := qryMain.FieldByName('FieldToIncrese').AsInteger +1; 
 else result := 1; 
end; 

... 

procedure TForm1.SetNextNumber; 
begin 
 //You must first see if the table is in insert/update mode before using this procedure. 
 tblMain.FieldByName('FieldToIncrese').AsInteger := GetNextNumber; 
end; 

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)