Получение SCOPE_IDENTITY от SQL Server при вставке

Думаю, уже слишком поздно, и я слишком устал, чтобы понять, что я делаю не так. Вот что я пытаюсь:

int imageId = imageDal.AddImage(new SqlParameter[]
        {
            new SqlParameter("@IMAGE_ID", 
        SqlDbType.Int, Int32.MaxValue, ParameterDirection.Output,
        true, 0, 0,"IMAGE_ID", DataRowVersion.Current,DBNull.Value),

        new SqlParameter("@IMAGE", 
        SqlDbType.Image, 11, ParameterDirection.Input,
        true, 0, 0,"IMAGE", DataRowVersion.Current,image)
        });

public int AddImage(SqlParameter[] spParams)
{
    SqlHelper.ExecuteNonQuery(BaseDAL.ConnectionStringImages, INSERT_IMAGE_SQL, spParams);
    return Convert.ToInt32(spParams[0].Value);
}

Хранимая процедура:

[dbo].[sp_insert_image]
    -- Add the parameters for the stored procedure here
    @IMAGE_ID int OUT,
    @IMAGE image
AS
BEGIN
    INSERT INTO images
    (IMAGE)
    VALUES
    (@IMAGE)
    SELECT @IMAGE_ID = SCOPE_IDENTITY();
END
GO

Я получаю DBNull как spParams[0]. Значение. Я попытался установить значение @IMAGE_ID на постоянную в моей хранимой процедуре, но это ничего не изменило, поэтому проблема не в моей хранимой процедуре (это то, что я думаю).

Когда я выполняю процедуру из студии управления sql, я вижу возвращенный insert_id..

3 ответа

Решение

Я закончил с Executescalar и возвращая SCOPE_IDENTITY() прямо из СП.

Если есть другой способ сделать это и получить значение из sqlparameter, я бы хотел это услышать.

Полагаю, проблема в методе ExecuteNonQuery. Он возвращает массив объектов, а не массив sqlparam.

Просто создайте ссылку на выходной объект sqlparam и получите значение из этой ссылки.

Удачи!

PS Есть другое решение. Проверьте ссылку

http://www.dotnetmonster.com/Uwe/Forum.aspx/dotnet-distributed-apps/160/Data-Access-Application-Block-Output-Parameters

Вы положили, как это....

[dbo].[sp_insert_image]
    -- Add the parameters for the stored procedure here
    @IMAGE_ID int OUT,
    @IMAGE image
AS
BEGIN
    INSERT INTO images (IMAGE) VALUES (@IMAGE)
    SET @IMAGE_ID  = SCOPE_IDENTITY();
END
GO
Другие вопросы по тегам