Модераторы: Partizan, gambit
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Связывание и отображение данных в DataGridView, программно 
:(
    Опции темы
iogun
Дата 9.11.2008, 13:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 17
Регистрация: 24.2.2007

Репутация: нет
Всего: нет



На форме имеется DataGridView. Хочу программно создать подключение к базе, к таблице и отобразить таблицу в этом компоненте. Запрос будет с параметром.
Код

 connStr = Properties.Settings.Default.controlordersConnectionString;
            conn = new SqlConnection(connStr);
            dsExecutors = new DataSet();
            conn.Open();
            string sqlSelectExecutors = "select * from executors where [order]=@order";
            dAdapterExecutors = new SqlDataAdapter(sqlSelectExecutors, conn);
            dAdapterExecutors.SelectCommand.CommandText = sqlSelectExecutors;
            dataGridView1.AutoGenerateColumns = true;

            SqlParameter[] spOrder = new SqlParameter[1];
            spOrder[0] = new SqlParameter("@order", System.Data.SqlDbType.NVarChar);
            spOrder[0].Value = this.order;
            spOrder[0].Direction = ParameterDirection.Input;
            dAdapterExecutors.SelectCommand.Parameters.Add(spOrder[0]);
            dataGridView1.DataSource = dsExecutors;
            dAdapterExecutors.Fill(dsExecutors, "ctrlo_executors");


выдается такая ошибка

"Prepared statement '(@order nvarchar(4000))select * from ctrlo_executors where [orde' expects parameter @order, which was not supplied."
а если использовать запрос без параметра то dataGridView остается пустым.
PM MAIL   Вверх
iogun
Дата 9.11.2008, 14:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 17
Регистрация: 24.2.2007

Репутация: нет
Всего: нет



Переписал код след. образом
Код

            string sqlSelectExecutors = "select * from ctrlo_executors";
            dAdapterExecutors = new SqlDataAdapter(sqlSelectExecutors, conn);
            dsExecutors = new DataSet();
 

            SqlParameter[] spOrder = new SqlParameter[1];
            spOrder[0] = new SqlParameter("@order", System.Data.SqlDbType.NVarChar);
            spOrder[0].Value = this.order;
            spOrder[0].Direction = ParameterDirection.Input;
            //dAdapterExecutors.SelectCommand.Parameters.Add(spOrder[0]);

            dAdapterExecutors.Fill(dsExecutors, "ctrlo_executors");
            dataGridView1.DataSource = dsExecutors.Tables["ctrlo_executors"].DefaultView;


если использую простой запрос select * from ctrlo_executors без параметра, то все нормально, грид заполняется.
если select * from ctrlo_executors where [order]=@order, и разремю строку dAdapterExecutors.SelectCommand.Parameters.Add(spOrder[0]);
то на строке 

Код

 dAdapterExecutors.Fill(dsExecutors, "ctrlo_executors");

вываливается ошибка 
Цитата

Prepared statement '(@order nvarchar(4000))select * from ctrlo_executors where [orde' expects parameter @order, which was not supplied.


Это сообщение отредактировал(а) iogun - 9.11.2008, 14:12
PM MAIL   Вверх
mr.DUDA
Дата 9.11.2008, 19:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


3D-маньяк
****


Профиль
Группа: Экс. модератор
Сообщений: 8244
Регистрация: 27.7.2003
Где: город-герой Минск

Репутация: 8
Всего: 232



А если без собачки?


--------------------
user posted image
PM MAIL WWW   Вверх
elbjarn
Дата 9.11.2008, 23:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 98
Регистрация: 13.4.2008
Где: Дубна

Репутация: 1
Всего: 3



зачем вам использовать массив скл-параметров из 1 элемента?
используйте метод sqlcommand.parameters.addwithvalue
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Прежде чем создать тему, посмотрите сюда:
Partizan
PashaPash

Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов.
Что делать если Вам помогли, но отблагодарить помощника плюсом в репутацию Вы не можете(не хватает сообщений)? Пишите сюда, или отправляйте репорт. Поставим :)
Так же не забывайте отмечать свой вопрос решенным, если он таковым является :)


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, mr.DUDA, Partizan, PashaPash.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | .NET для новичков | Следующая тема »


 




[ Время генерации скрипта: 0.0692 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.