Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.98/48: Рейтинг темы: голосов - 48, средняя оценка - 4.98
 Аватар для Fahrenheit451
2 / 2 / 1
Регистрация: 01.02.2010
Сообщений: 15

Как программно вывести данные из таблицы базы ms sql на форму в dataGridView

13.02.2010, 16:00. Показов 9951. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ребят, подскажите как программно вывести данные из таблицы базы ms sql на форму в dataGridView. Покажите пример на Visual C++ с использованием OLE (OleDbConnection, OleDbCommand и тд), если не трудно. В интернете полно примеров на C#, но вот для Visual C++ совсем мало... Помогите, второй день уже бьюсь, не могу вывести эту таблицу.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.02.2010, 16:00
Ответы с готовыми решениями:

Как с помощью MonthCalendar вывести в DataGridView с sql таблицы данные с определенной датой?
Всем доброго времени суток! Подскажите пожалуйста как с помощью MonthCalendar вывести в DataGridView с sql таблицы данные которые записаны...

Как в DataGridView записать программно данные, добавить строку и вывести туда итог
Доброе время суток! Подскажите пожалуйста как сделать следующее У меня вывело результат из mysql хочу красиво дописать в низу строку...

Как программно изменить источник данных DataGridView или как вывести в DatagGridView разные таблицы
В студии в визуальном редакторе могу изменить источник. Но как изменить программно. Добавлено через 56 минут Разобрался сам, доделаю...

10
9 / 8 / 0
Регистрация: 03.02.2010
Сообщений: 28
14.02.2010, 13:47
Цитата Сообщение от Fahrenheit451 Посмотреть сообщение
Ребят, подскажите как программно вывести данные из таблицы базы ms sql на форму в dataGridView. Покажите пример на Visual C++ с использованием OLE (OleDbConnection, OleDbCommand и тд), если не трудно. В интернете полно примеров на C#, но вот для Visual C++ совсем мало... Помогите, второй день уже бьюсь, не могу вывести эту таблицу.
Ну, во первых - таблицу из базы можно вывести как-то непрограммно? Даже если в VS воспользоваться конструктором - то он все равно создаст код, который можно посмотреть.

И чем таким принципиальным отличается код C++ от С#? .NET везде один и тот же.
1
 Аватар для Fahrenheit451
2 / 2 / 1
Регистрация: 01.02.2010
Сообщений: 15
14.02.2010, 16:40  [ТС]
Цитата Сообщение от Monochrome Посмотреть сообщение
Ну, во первых - таблицу из базы можно вывести как-то непрограммно? Даже если в VS воспользоваться конструктором - то он все равно создаст код, который можно посмотреть.

И чем таким принципиальным отличается код C++ от С#? .NET везде один и тот же.
Да, конечно код везде выводится программно, я имела в виду написание кода вручную, без использования конструктора... Дело в том, что посмотреть мне просто негде, у меня в Visual studio 2008 невозможно подключить базу данных с помощью конструктора (в мастере настройки источников данных нет базы данных, есть только объект). Если бы можно было конструктором все подключить и посмотреть на сгенерированный код, я бы это сделала...
Конечно, для опытного программиста нет вообще никакой разницы между синтаксисом С++ и С#, в том смысле что он может тут же и сразу перевести с одного на другой язык. Но я всего лишь новичок, изучающий С++ всего пару недель...

Добавлено через 2 часа 34 минуты
Ребят, попробовала добавить на форму dataGridView1(без столбцов, проста пустую табличку) и вот такой код написать:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private: System::Void Form1_Load(System::Object^  sender, System::EventArgs^  e) 
  {    
             String^ myConnectionString;
            myConnectionString= L"Provider=SQLNCLI.1;Data Source=Erghd\\Erghd;Integrated Security=SSPI;Initial Catal" 
                L"og=Sddds";
  OleDbConnection^ myConnection = gcnew OleDbConnection(myConnectionString);
 OleDbDataAdapter^ adapt = gcnew OleDbDataAdapter("SELECT * FROM users", myConnection);
            System::Data::DataSet^ ds = gcnew System::Data::DataSet(); 
            adapt->Fill(ds, "users");
 
            dataGridView1->DataSource = ds;
            dataGridView1->DataMember = "users";
 
                       
             }
Ошибок не происходит, все компилируется, но таблица получается пустая, подскажите, я уже просто даже не знаю в чем ошибка...
0
9 / 8 / 0
Регистрация: 03.02.2010
Сообщений: 28
14.02.2010, 17:19
Цитата Сообщение от Fahrenheit451 Посмотреть сообщение
Ошибок не происходит, все компилируется, но таблица получается пустая, подскажите, я уже просто даже не знаю в чем ошибка...
А в базу-то информация заведена? Для меня было сюрпризом, что MS VS сама копирует мою базу в bin\debug\ и читает данные ОТТУДА, а я вносил изменения в базу, которая лежит на привычном для меня месте.
1
 Аватар для Fahrenheit451
2 / 2 / 1
Регистрация: 01.02.2010
Сообщений: 15
14.02.2010, 18:02  [ТС]
Цитата Сообщение от Monochrome Посмотреть сообщение
А в базу-то информация заведена? Для меня было сюрпризом, что MS VS сама копирует мою базу в bin\debug\ и читает данные ОТТУДА, а я вносил изменения в базу, которая лежит на привычном для меня месте.
Как раз дело не базе MS SQL, а в Form1_Load, даже не понимаю почему перед загрузкой формы в таблицу не загружаются данные...
Я пошла другим путем, поместила на форму кнопку и сделала обработчик для него, но другого вида, вот такой:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
private: System::Void button1_Click(System::Object^  sender, System::EventArgs^  e) {
         String^ myConnectionString;
                        myConnectionString= L"Provider=SQLNCLI.1;Data Source=Erghd\\Erghd;Integrated Security=SSPI;Initial Catal" 
                                L"og=Sddds";
 
                 OleDbConnection^ myConnection = gcnew OleDbConnection(myConnectionString);
                 
                  String^ mySelectQuery = "SELECT * FROM users";
                 OleDbCommand^ myCommand = gcnew OleDbCommand(mySelectQuery);
                 myCommand->Connection = myConnection;
                 myConnection->Open();
                 
                 OleDbDataReader^ myReader = myCommand->ExecuteReader();
               int cnt = 0;
 
                    while(myReader->Read())
                       {
                          if (myReader[0]->ToString() != "")
                    {
                        dataGridView1->Rows->Add();
                        dataGridView1->Rows[cnt]->Cells[0]->Value = myReader["id_user"]->ToString();
                        dataGridView1->Rows[cnt]->Cells[1]->Value = myReader["name_user"]->ToString();
                        dataGridView1->Rows[cnt]->Cells[2]->Value = myReader["password"]->ToString();
                        cnt++;
                    }
 
                       }
                       myReader->Close();
                 myConnection->Close();
             
             }
При нажатии на кнопку, таблица заполняется, это хорошо...
Но как мне все таки произвести загрузку данных в форму при ее открытии?
Что я делаю неправильно?
0
9 / 8 / 0
Регистрация: 03.02.2010
Сообщений: 28
14.02.2010, 18:34
1. У вас вообще процедура выполняется по загрузке формы?
2. На одном форуме видел решение - выполнить dataGridView.acceptChanges(); в самом конце
1
 Аватар для Fahrenheit451
2 / 2 / 1
Регистрация: 01.02.2010
Сообщений: 15
14.02.2010, 19:14  [ТС]
Цитата Сообщение от Monochrome Посмотреть сообщение
1. У вас вообще процедура выполняется по загрузке формы?
2. На одном форуме видел решение - выполнить dataGridView.acceptChanges(); в самом конце
Дело в том, что процедура при загрузке формы у меня действительно не работает...Проверила это я опытным путем, объявила переменную и затем присвоила ей значение в процедуре по загрузке и вывела по клику на кнопку. Можно конечно и как то по другому это проверить, но у меня опыта маловато, сделала как сумела:
C++
1
2
3
4
5
6
7
8
9
10
11
public: String^ fg;
private: void Form1_Load(Object^  sender, EventArgs^  e) 
  {    
    
fg="5";       
             }
    private: System::Void button1_Click(System::Object^  sender, System::EventArgs^  e) {
 
                 button1->Text = "button1"+fg;  
                
             }
Надпись на кнопке так и не поменялась при клике на нее...
Может быть дело в том, что я неправильно вставляю эту процедуру при загрузке формы? Она изначально не формируется конструктором, я ее сама добавляю где то в конце класса:
C++
1
2
3
public ref class Form1 : public System::Windows::Forms::Form{    
    
 }
Извините, за столь ламерский вопрос...
0
9 / 8 / 0
Регистрация: 03.02.2010
Сообщений: 28
14.02.2010, 21:12
Не надо извиняться. Вам проще всего сделать следующее:
1. Открыть форму в режиме дизайнера.
2. Вызвать свойства формы (именно самй формы, не каких-либо элементов на ней)
3. В свойствах переключиться на события (желтая молния)
4. Найти событие on load (или как-то так)
5. И вписать туда название свой процедуры. И все получится.
1
 Аватар для Fahrenheit451
2 / 2 / 1
Регистрация: 01.02.2010
Сообщений: 15
15.02.2010, 11:48  [ТС]
Цитата Сообщение от Monochrome Посмотреть сообщение
Не надо извиняться. Вам проще всего сделать следующее:
1. Открыть форму в режиме дизайнера.
2. Вызвать свойства формы (именно самй формы, не каких-либо элементов на ней)
3. В свойствах переключиться на события (желтая молния)
4. Найти событие on load (или как-то так)
5. И вписать туда название свой процедуры. И все получится.
Все проделала как вы сказали и получилось! Табличка загружается двумя способами при загрузке формы.

Спасибо вам, правда, очень признательна. Столько со мной возились, объяснили все подробно.
0
1 / 1 / 0
Регистрация: 16.02.2010
Сообщений: 6
16.02.2010, 23:42
Рекомендую попробовать FastSQLDataSource. Этот контрол ставится вместо стандартного SQLDataSource и существенно ускоряет отображение из базы MS SQL в гридах, списках и других Bound контролах. На сайте разработчика http://www.nitrosbase.net есть примеры приложений.
1
 Аватар для Fahrenheit451
2 / 2 / 1
Регистрация: 01.02.2010
Сообщений: 15
17.02.2010, 12:36  [ТС]
Цитата Сообщение от graphic Посмотреть сообщение
Рекомендую попробовать FastSQLDataSource. Этот контрол ставится вместо стандартного SQLDataSource и существенно ускоряет отображение из базы MS SQL в гридах, списках и других Bound контролах. На сайте разработчика http://www.nitrosbase.net есть примеры приложений.
Спасибо, попробую
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.02.2010, 12:36
Помогаю со студенческими работами здесь

Как правильно передать данные из таблицы DataGridView в SQL базу данных
Здравствуйте. Есть таблица DataGridView которая содержит данный которые добавляет пользователь или загружает из файла. Как мне правильно...

Как вывести данные из БД MS SQL в DataGridView, когда таблица составная
Ребят, всем привет! Подскажите как вывести данные из бд в DataGridView, когда таблица составная? И как после редактировать её и тд? ...

Как вывести данные из БД SQL на форму, чтобы затем изменить их?
Как вывести данный из БД SQL в типе (int) на форму чтобы изменить его....(подробнее в скриншот) try { ...

Как вывести данные из таблицы Access в DataGridView используя ComboBox?
Подскажите как мне вывести данные из таблицы access в datagridview используя combobox. Очень необходимо. Четвертый день ползаю по сети и не...

Как вывести в gridview данные связующей таблицы реляционной базы данных?
Доброго времени суток. Помогите, пожалуйста, решить задачу. Есть простейшая база данных из 5 связных таблицы как вывести в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru