Hi There,
I'm having a problem retreiving the auto generated Guid after inserting anew record with NEWID(), my stored proc is as follows:
SET @.uiTransactionID = NEWID()INSERT INTO Transactions (uiTransactionID) VALUES (@.uiTransactionID)IF @.@.ERROR = 0 AND @.@.ROWCOUNT = 1BEGIN SELECT @.uiTransactionID AS'@.@.GUID' RETURN 0END
And the return on my insert statement is:
command.ExecuteNonQuery();
m_uiTransactionID = (Guid
I can never retreive the newly generated Guid, can onyone spot where i'm going wrong?
Many thanks
Ben
Hi,
i have tested your stored procedure and i think the stored procedure is correct. Please check your calling code for the stored procedure:
protected void CallStoredProcedure(){ Guid m_uiTransactionID; SqlCommand cmd =new SqlCommand("Test",new SqlConnection(ConfigurationManager.ConnectionStrings["DataBase"].ToString()));cmd.CommandType = CommandType.StoredProcedure;cmd.Parameters.Add("@.uiTransactionID", SqlDbType.UniqueIdentifier);cmd.Parameters["@.uiTransactionID"].Direction = ParameterDirection.Output;try { cmd.Connection.Open(); cmd.ExecuteNonQuery();m_uiTransactionID = (Guid)cmd.Parameters["@.uiTransactionID"].Value; }catch (Exception exc) { }finally { cmd.Connection.Close(); }}
And you can also check the stored procedure execute permissons.
Hope this can help you.
Regards
Marc André
Hi Marc,
Thanks for your reply, you've helped me agreat deal and it is now working.
Many thnks
Ben
No comments:
Post a Comment