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

Вниз

Identity в базе SQLServer   Найти похожие ветки 

 
Alexey ©   (2004-04-06 18:12) [0]

Как вытащить индентификатор из таблицы после выполнения ADOQeery в Дельфях6 функция в кваери isnert, а также записать его в параметр, база SQL ???


 
Black Krok   (2004-04-06 18:19) [1]

У меня сработал такой вариант:


INSERT INTO orientir_bases (NAME)
      VALUES ("")
      RETURNING id INTO :IDBase


При добавлении срабатывает триггер, записывающий в поле id значение из счетчика. После отработки команды в параметре IDBase
я получаю содержимое этого поля


 
KSergey ©   (2004-04-07 07:50) [2]

> Black Krok   (06.04.04 18:19)

Это синтаксис для како сервера? Какой версии?

Вообще код примерно такой:

INSERT (...) VALUES (...)
SELECT @@IDENTITY

Для MS SQL 2000 вместо @@IDENTITY надо использовать @@SCOPE_IDENTITY (примерно так, справки под рукой нет)

Тогда запрос вернет одну запись из одного столбца, в которм будет последнее ID

Ну и в случае MS SQL ниже 2k почитать об ограничениях на @@IDENTITY


 
Alexey ©   (2004-04-07 09:22) [3]

Сервер MS SQL 2000 вариант:

INSERT INTO orientir_bases (NAME)
     VALUES ("")
     RETURNING id INTO :IDBase

не пашет, выдает ошибку какую забыл ... потом посмотрю. На счет @@scope_identity не знаю чуть позже посмотрю


 
roottim   (2004-04-07 09:52) [4]

>RETURNING id INTO :IDBaseэто по ОРАКЛУ..

а МССКЛ блокировочник и после вставки , как я понимаю, необходимо именно прочитать эту @@IDENTITY, после чего  блокировка снимется и другие транзакции продолжат вставку.. ну или что там...


 
Alexey ©   (2004-04-07 17:54) [5]

Всем спасибо ... ошибка была в другой ереси ... слега напутал ... кстати один из правильных вариантов такой:

В кваери
select @@IDENTITY AS ID

В Дельфях
параметр:=ADOQuery["ID"]

параметр: integer



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

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

Наверх




Память: 0.48 MB
Время: 0.027 c
1-1081957227
kEY//
2004-04-14 19:40
2004.05.02
HotKeys


9-1068576879
DDS
2003-11-11 21:54
2004.05.02
OpenGL: Поворот координатных осей и движение


3-1081096181
Walker Hippi
2004-04-04 20:29
2004.05.02
InterBase в сети


8-1075539418
Millennium
2004-01-31 11:56
2004.05.02
скриншот


6-1078344029
AlexeyITN
2004-03-03 23:00
2004.05.02
Есть ли комп в сети? да и по-дешевле...