Re[3]: INSERT ..... SELECT .... за раз
От: Sshur Россия http://shurygin-sergey.livejournal.com
Дата: 20.11.06 13:46
Оценка:
Здравствуйте, prockrut, Вы писали:

S>>Можно попытаться сделать встроенную процедуру и передать identity оттуда в качестве output параметра.


S>>ЗЫ. Вместо @@identity лучше использовать scope_identity(), так как в случае наличия на таблице триггеров, вставляющих данные в другие таблице @@identity вернет значение счетчика не из той таблицы.



P>Не нашел, что значит встроенная процедура

P>Сделал Stored Procedure
P>Вопрос: как извлечь id?

Чтобы значение возвращалось надо делать так:



==================================================================
CREATE PROCEDURE NewObject
@Name nvarchar,
@id int output
AS
INSERT INTO MyObjects([Name]) VALUES(@Name)
SET @id= @@IDENTITY -- либо SCOPE_IDENTITY()
GO
==================================================================



P>Вариант

P>
P>SQLExecDirect(hStmt, "DECLARE @id int EXECUTE CreateAsset NewObject, 'Name' @id OUTPUT SELECT @id AS [Identity]", SQL_NTS);
P>


P>Опять же не проходит



По работе с ODBC я не большой советчик, могу сказать только что надо параметры привязывать к команде посредством SQLBindParameter, и смотреть потом после выполнения команды. Если SQLExecDirect с параметрами не работает, то придеться использовать SQLPrepareStmt/SQLExec (за правильность названий не ручаюсь).
Шурыгин Сергей

"Не следует преумножать сущности сверх необходимости" (с) Оккам
 
Подождите ...
Wait...
Пока на собственное сообщение не было ответов, его можно удалить.