Ошибка неверного имени объекта при попытке выполнить хранимую процедуру? - PullRequest
3 голосов
/ 15 мая 2009

Не уверен, в чем дело, у меня есть хранимая процедура, названная точно как я вызываю, однако она всегда дает мне эту ошибку недопустимого объекта. Вот код подключения, ошибка выдается там со второй до последней строки.

SqlConnection cnstr = new SqlConnection(ConfigurationManager.ConnectionStrings["darconn"].ConnectionString);
SqlCommand sqlcmd = new SqlCommand();

sqlcmd.CommandType = CommandType.StoredProcedure;
sqlcmd.Connection = cnstr;
sqlcmd.CommandText = "SetMapping";

String[] pullKodID = bundlelist.SelectedValue.ToString().Split(':');
int kod_id = System.Convert.ToInt32(pullKodID[0]);

sqlcmd.Parameters.Add("@kod_id", kod_id);
sqlcmd.Parameters.Add("@ell_id", courselist.Items[i].Text);
cnstr.Open();
sqlcmd.ExecuteNonQuery();
cnstr.Close();

Ответы [ 14 ]

0 голосов
/ 07 июля 2010

Как называется реальный объект, на который он жалуется? Я видел ту же проблему в хранимом процессе, и на самом деле не было проблем со sproc как таковым, но из-за опечатки имя таблицы, используемой в хранимом процессе, было неверным (имя sproc было случайно вставлено как имя таблицы), поэтому он вернул ошибку Invalid Object name, которая соответствовала имени sproc - что очень сбивало с толку.

Попробуйте изменить имя sproc и снова вызвать его из своего кода и посмотреть, что произойдет - или попробуйте запустить sproc непосредственно в SQL Management Studio.

Если это не сработает, будьте очень методичны, разделяйте и властвуйте - вернитесь к основам и проверьте все снова и снова. Правильна ли строка подключения, к какой базе данных она подключается во время выполнения, к какому идентификатору пользователя, sproc работает в Sql management studio самостоятельно и т. Д.

Надеюсь, это поможет.

0 голосов
/ 16 мая 2009

Используется ли в базе данных сортировка с учетом регистра? Если да, то совпадает ли регистр в вашем коде C # с регистром в базе данных?

0 голосов
/ 15 мая 2009

Это длинный выстрел, но общие ответы уже перечислены.

Редко сценарий может получить другое имя в каталоге, чем в сценарии. Я считаю, что это может вызвать проблемы, похожие на то, что вы видите.

Следующий скрипт проверит вашу базу данных на предмет наличия в вашем каталоге элементов, которые не соответствуют этому сценарию. (Вам нужен SQL 2005 или выше, чтобы это работало)

-------------------------------------------------------------------------
-- Check Syntax of Database Objects
-- Copyrighted (2009).  Free to use as a tool to check your own code or in 
--  any software not sold. All other uses require written permission from Author
-- Author: Stephen Schaff
-------------------------------------------------------------------------
-- Turn on ParseOnly so that we don't actually execute anything.
SET PARSEONLY ON 
GO

-- Create a table to iterate through
declare @ObjectList table (ID_NUM int NOT NULL IDENTITY (1, 1), OBJ_NAME varchar(255), OBJ_TYPE char(2))

-- Get a list of most of the scriptable objects in the DB.
insert into @ObjectList (OBJ_NAME, OBJ_TYPE)
SELECT   name, type
FROM     sysobjects WHERE type in ('P', 'FN', 'IF', 'TF', 'TR', 'V')
order by type, name

-- Var to hold the SQL that we will be syntax checking
declare @SQLToCheckSyntaxFor varchar(max)
-- Var to hold the name of the object we are currently checking
declare @ObjectName varchar(255)
-- Var to hold the type of the object we are currently checking
declare @ObjectType char(2)
-- Var to indicate our current location in iterating through the list of objects
declare @IDNum int
-- Var to indicate the max number of objects we need to iterate through
declare @MaxIDNum int
-- Set the inital value and max value
select  @IDNum = Min(ID_NUM), @MaxIDNum = Max(ID_NUM)
from    @ObjectList

-- Begin iteration
while @IDNum <= @MaxIDNum
begin
  -- Load per iteration values here
  select  @ObjectName = OBJ_NAME, @ObjectType = OBJ_TYPE
  from    @ObjectList
  where   ID_NUM = @IDNum 

  -- Get the text of the db Object (ie create script for the sproc)
  SELECT @SQLToCheckSyntaxFor = OBJECT_DEFINITION(OBJECT_ID(@ObjectName, @ObjectType))

  begin try
    -- Run the create script (remember that PARSEONLY has been turned on)
    EXECUTE(@SQLToCheckSyntaxFor)
  end try
  begin catch
    -- See if the object name is the same in the script and the catalog (kind of a special error)
    if (ERROR_PROCEDURE() <> @ObjectName)
    begin
      print 'Error in ' + @ObjectName
      print '  The Name in the script is ' + ERROR_PROCEDURE()+ '. (They don''t match)'
    end

  end catch

  -- Setup to iterate to the next item in the table
  select  @IDNum = case
            when Min(ID_NUM) is NULL then @IDNum + 1
            else Min(ID_NUM)
          end  
  from    @ObjectList
  where   ID_NUM > @IDNum

end
-- Turn the ParseOnly back off.
SET PARSEONLY OFF 
GO

(Примечание: если вы хотите увидеть все ошибки в вашей базе данных, добавьте это после блока if (ERROR_PROCEDURE() <> @ObjectName).)

else if (ERROR_MESSAGE() <> 'There is already an object named ''' + ERROR_PROCEDURE() + ''' in the database.')
begin
  -- Report the error that we got.
  print 'Error in ' + ERROR_PROCEDURE()
  print '  ERROR TEXT: ' + ERROR_MESSAGE() 
end
0 голосов
/ 15 мая 2009

Вы абсолютно уверены, что правильно ввели имя?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...