Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Не могу передать параметры сохраненной процедуре  (Прочитано 9160 раз)
0 Пользователей и 2 Гостей смотрят эту тему.
Serega
Гость
« : 15-11-2004 13:41 » 

Код:
OdbcCommand command = new OdbcCommand();
command.CommandText = "AddRawData";
command.CommandType = System.Data.CommandType.StoredProcedure;
command.Parameters.Add("@dev_id", OdbcType.Int);
command.Parameters.Add("@dev_type", OdbcType.Int);
command.Parameters.Add("@data_type", OdbcType.Int);
command.Parameters.Add("@value", OdbcType.Double);
command.Parameters.Add("@time", OdbcType.DateTime);
command.Connection = connection;
connection.Open();

command.Parameters[0].Value = device.Id;
command.Parameters[1].Value = device.Type;
command.Parameters[2].Value = dataType;
command.Parameters[3].Value = value;
command.Parameters[4].Value = DateTime.Now;
command.ExecuteNonQuery();
Получаю вот такой exception:
"ERROR [42000] [Microsoft][ODBC SQL Server Driver][SQL Server]Procedure 'AddRawData' expects parameter '@dev_id', which was not supplied."

Как же обьяснить MSSQL что я всетаки передаю параметры ?
« Последнее редактирование: 02-12-2007 18:03 от Алексей1153++ » Записан
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #1 : 15-11-2004 14:03 » 

1. А типы совпадают?

2. В случае INSERT'а ключевые поля с автоинкрементом нельзя заполнять. В этом случае будет ругань на "лишние" параметры.

Скорее твой всего вариант 2.
Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
Serega
Гость
« Ответ #2 : 17-11-2004 07:52 » 

Автоинкремента нет

Насчет типов не знаю, процедурка на MSSQL, VS сгенерил мне код параметров для System.Data.SqlTypes, но мне нужно ODBC
Записан
Y3YPnATOP
Гость
« Ответ #3 : 17-11-2004 08:26 » 

А если попробовать
sqlPrm.Direction = ParameterDirection.InputOutput;
назначать?! Хотя это конечно врядли
2Serega: Выложи код процедурки
Записан
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #4 : 17-11-2004 11:26 » 

а ты процедуру в QA вручную запускал через exec? может, это в процедуре бага
Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
Serega
Гость
« Ответ #5 : 18-11-2004 10:04 » 

Код:
PROCEDURE AddRawData
@dev_id int,
@dev_type int,
@data_type int,
@value float,
@time datetime
AS
INSERT INTO raw VALUES(@dev_id, @dev_type, @data_type, @value, @time)
процедурка пока простая, пусть сначала это заработает
« Последнее редактирование: 02-12-2007 18:04 от Алексей1153++ » Записан
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #6 : 18-11-2004 13:07 » new

ну так и выполни её в QA.

Код:

declare @dev_id int, @dev_type int, @data_type int, @value float, @time datetime
set @dev_id = ..... -- присвой чего надо
....
exec AddRawData @dev_id, @dev_type, @data_type, @value, @time


Прошло?

Всё ж, если мне память не изменяет, бага связана с заполнением ключевого поля. Получал я такую ошибку, но давно было - не помню точно.

Ещё можно попробовать не через SqlParameter делать, а напрямую формировать строчку с параметрами (для проверки глюка по варианту 1).

Попробуй убрать ключевое поле из Insert.
Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines