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

Вниз

инкрементирования   Найти похожие ветки 

 
DWW   (2004-11-16 08:07) [0]

Помогите пожалуйста разобраться что нужно подставить
Это то я нашел для ключевого поля, его инкрементирования
Определение хранимой процедуры:

 Create Procedure NewEmployeeKey Returns ( EmployeeKey Integer ) as
 begin
   EmployeeKey = Gen_Id( gnEmployeeKey, 1 ) ;
 end
Определение триггера:
 Create Trigger SetEmployeeKey for tbEmployee Active Before Insert Position 0 as
 begin
   if ( New.EmployeeKey is Null ) then begin
     Execute Procedure NewEmployeeKey Returning_Values New.EmployeeKey ;
   end
 end


 
Rule ©   (2004-11-16 08:51) [1]

чегото ты намудрил, зачем тебе процедура
юзай IBExpert  и посмотри что он генерит

сначала создаешь генератор для своей таблицы
CREATE GENERATOR gnEmployeeKey

а мотом тригер перед вставкой
CREATE TRIGGER SetEmployeeKey FOR tbEmployee
ACTIVE BEFORE INSERT POSITION 0
AS
BEGIN
 IF (NEW.EmployeeKey IS NULL) THEN
   NEW.EmployeeKey = GEN_ID(SetEmployeeKey,1);
END

вот так вот
причем автоинкремент, как видно из кода, можно делать и не на ключевый полях (только тогда смысл непонятен) или по условию или ещё чего хочешь ...


 
DWW   (2004-11-16 22:28) [2]

А как получить его (значение генератора) в Delphi, у меня не получалось


 
DrPass ©   (2004-11-17 00:10) [3]

Если используешь для его вставки триггер, то ты его не получишь, да и не надо - оно само вставится.
Если ты все же хочешь его получить, убери триггер, а получай запросом вида select GEN_ID(SetEmployeeKey,1) from rdb$database,
а потом уже делай с ним что хочешь.


 
Sergey13 ©   (2004-11-17 09:53) [4]

2[3] DrPass ©   (17.11.04 00:10)
>Если ты все же хочешь его получить, убери триггер,
Зачем убирать? Он не мешает. 8-)



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

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

Наверх




Память: 0.47 MB
Время: 0.023 c
1-1101977867
гость
2004-12-02 11:57
2004.12.19
удаление файла из listview


14-1101407893
Ломборозо
2004-11-25 21:38
2004.12.19
Новости в RSS или TXT


1-1102367669
Поручик
2004-12-07 00:14
2004.12.19
Что-то я торможу (


3-1100872886
Wolffgang
2004-11-19 17:01
2004.12.19
fkCalculated = -1, потом 2


8-1095298644
Ozone
2004-09-16 05:37
2004.12.19
Обход контура в BitMap