Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/18: Рейтинг темы: голосов - 18, средняя оценка - 4.78
1 / 1 / 0
Регистрация: 06.08.2015
Сообщений: 35

DataGridView в Цикле FOR как сделать заполнение?

06.08.2015, 11:10. Показов 3414. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте добрые люди.
Всю голову сломал, не могу понять как мне заполнить DataGridView из цикла.... в цикле получаю данные из SQL и mdb. Выводит всё время последние результаты прохождения цикла.
Вот мой код :
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
  int i;
          
          
            for (i = 0; i < 3; i++)
            {
                OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\\db\\data.mdb");
                OleDbCommand myCommand = new OleDbCommand("Select * From centrum", conn);
 
                //открываем соединение
                conn.Open();
                //вводим запрос к базе
                OleDbDataAdapter adapter1 = new OleDbDataAdapter(myCommand);
                adapter1.SelectCommand = myCommand;
                //записываем результат запроса в переменную ds1
                DataSet ds1 = new DataSet();
                adapter1.Fill(ds1);
                int k = i + 1;
                //разбиваем строку на колонки и присваеваем каждой переменной своё значение колонки
                string IPTest = ds1.Tables[0].Rows[k][3].ToString();
                string DbTest = ds1.Tables[0].Rows[k][4].ToString();
                string Dbtabl = ds1.Tables[0].Rows[k][5].ToString();
                //закрываем соединение
                conn.Close();
 
                if (CheckServers(IPTest))
                {
                    string Connect = "Data Source=" + IPTest;
                    string Connect1 = ";Initial Catalog=" + DbTest;
                    string Connect2 = ";Persist Security Info=True; Provider=SQLOLEDB;User ID=sa;Password=mssql2013";
                    connection = new OleDbConnection(Connect + Connect1 + Connect2);
 
                    //очистка таблицы dataSet
                    //   dataSet.Tables.Clear();
                    //начало соединения
                    dataSet = new DataSet();
                    connection.Open();
                    System.Data.DataTable DT = new System.Data.DataTable("Dbtabl");
                    OleDbDataAdapter adapter = new OleDbDataAdapter(str, connection);
                    dataSet.Tables.Add(DT);
                    adapter.Fill(dataSet, "Dbtabl");
                    //заполняем dataset
                    //bindingSource = new BindingSource( dataSet, "Dbtabl");
                    bindingSource = new BindingSource(dataSet, "Dbtabl");
                    //передаём данные из dataset в datagridview
 
                    // dataGridView1.DataSource = bindingSource;
                    
                    // textBox2.Text += "\n" + (bindingSource[i + 1]).ToString() + "\r\n";
                    //очищаем datdset
                    // dataSet.Tables.Clear();
                    //закрываем соединение
                    connection.Close();
                }
                else
                {
                    MessageBox.Show("Ошибка соединения");
 
                }
               
            }
            dataGridView1.DataSource = bindingSource;
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.08.2015, 11:10
Ответы с готовыми решениями:

Заполнение dataGridView в цикле
Имеется textbox содержащий очень длинное слово. Имеется дата грид например с 5 столбцами и 5 строчками. Как перенести текст из текстбокса в...

Заполнение цифрами ячеек datagridView в цикле
Хочу чтобы в ячейках заполнялись данные з числами каждые 2,4,8 разы менялись(типа каждые 2:rows=1 rows=1 rows=0 rows=0 ) и не могу найти...

DataGridView: добавление строк и заполнение их данными в цикле
Подскажите пожалуйста, в чем ошибка? private void wr() { for (int i = 0; i &lt; 10; i++) ...

4
 Аватар для Adadjio
61 / 61 / 32
Регистрация: 30.07.2013
Сообщений: 178
06.08.2015, 21:28
В теле цикла у вас постоянно создаются новые экземпляры как DataSet-а так и DataTable. В следствии чего вы и получаете результаты последнего прохода в цикле. Вынесите создание всех этих объектов за тело цикла.
0
1 / 1 / 0
Регистрация: 06.08.2015
Сообщений: 35
07.08.2015, 02:18  [ТС]
Огромное спасибо. сначала выносил DataSet за пределы цыкла авот про Data Table забыл совсем.
Может кому пригодится моя процедура. Она берёт адреса и имена БД из mdf файла Access по ранее присвоенному ID номеру, после в цикле идёт подключение к IP указанных в базе Access и выполняется заданный запрос SQL. Т.е. позволяет прогнять один и тот же запрос SQL на нескольких серверах.
Вот исправленная процедура:
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
int i;
 //очистка таблицы dataSet
                    //   dataSet.Tables.Clear();
                    //начало соединения
                    dataSet = new DataSet();
System.Data.DataTable DT = new System.Data.DataTable("Dbtabl");
           dataSet.Tables.Add(DT);
          
            for (i = 0; i < 3; i++)
            {
                OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\\db\\data.mdb");
                OleDbCommand myCommand = new OleDbCommand("Select * From centrum", conn);
 
                //открываем соединение
                conn.Open();
                //вводим запрос к базе
                OleDbDataAdapter adapter1 = new OleDbDataAdapter(myCommand);
                adapter1.SelectCommand = myCommand;
                //записываем результат запроса в переменную ds1
                DataSet ds1 = new DataSet();
                adapter1.Fill(ds1);
                int k = i + 1;
                //разбиваем строку на колонки и присваеваем каждой переменной своё значение колонки
                string IPTest = ds1.Tables[0].Rows[k][3].ToString();
                string DbTest = ds1.Tables[0].Rows[k][4].ToString();
                string Dbtabl = ds1.Tables[0].Rows[k][5].ToString();
                //закрываем соединение
                conn.Close();
 
                if (CheckServers(IPTest))
                {
                    string Connect = "Data Source=" + IPTest;
                    string Connect1 = ";Initial Catalog=" + DbTest;
                    string Connect2 = ";Persist Security Info=True; Provider=SQLOLEDB;User ID=sa;Password=mssql2013";
                    connection = new OleDbConnection(Connect + Connect1 + Connect2);
 
                   
                    connection.Open();
                    
                    OleDbDataAdapter adapter = new OleDbDataAdapter(str, connection);
                   
                    adapter.Fill(dataSet, "Dbtabl");
                    //заполняем dataset
                    //bindingSource = new BindingSource( dataSet, "Dbtabl");
                    bindingSource = new BindingSource(dataSet, "Dbtabl");
                    //передаём данные из dataset в datagridview
 
                    // dataGridView1.DataSource = bindingSource;
                    
                    // textBox2.Text += "\n" + (bindingSource[i + 1]).ToString() + "\r\n";
                    //очищаем datdset
                    // dataSet.Tables.Clear();
                    //закрываем соединение
                    connection.Close();
                }
                else
                {
                    MessageBox.Show("Ошибка соединения");
 
                }
               
            }
            dataGridView1.DataSource = bindingSource;
0
1 / 1 / 0
Регистрация: 06.08.2015
Сообщений: 35
15.08.2015, 03:46  [ТС]
Прошу прощения. не стал создавать новую тему так как в принципе всё с этим же мучаюсь. На данный момент никак не могу решить вопрос с правильным выводом в DataGridView. Вот есть 2 типа строк которые хранятся в базах SQL
20150813 номер сокращение 00000,000 000000,00 2015-08-14 16:16:00
20150813 номер сокращение 0,00 0,00 1900-01-01 00:00:00
по крайней мере так выдаёт запрос если выполняется в менеджере sql, так вот а у меня в DataGrid выводится всё по другому: где в SQL 0,00, то в DataGrid почему то 0,000. А дату выводит 1 августа 2015 года.
вот и как это исправить не понимаю перерыл всё уже, думал даже записывать построчно в каждый столбик отдельно и менять как то формат столбца... но ничего не получилось....
Вод новый код процедуры.
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
       private void script_all(string str)
        {
            int i;
            //объявляем DataSet новый
            dataSet = new DataSet();
 
            System.Data.DataTable DT = new System.Data.DataTable("Dbtabl");
            dataSet.Tables.Add(DT);
            for (i = -1; i < 3; i = i + 1)
            {
                if (!(File.Exists("C:\\db\\data.mdb")))
                {
                    MessageBox.Show("Файл базы данных не удалось найти");
                }
                else
                {
                    OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\\db\\data.mdb");
                    OleDbCommand myCommand = new OleDbCommand("Select * From centrum", conn);
                    //открываем соединение
                    conn.Open();
                    //вводим запрос к базе
                    OleDbDataAdapter adapter1 = new OleDbDataAdapter(myCommand);
                    adapter1.SelectCommand = myCommand;
                    //записываем результат запроса в переменную ds1
                    DataSet ds1 = new DataSet();
                    adapter1.Fill(ds1);
                    int k = i + 1;
                    //разбиваем строку на колонки и присваеваем каждой переменной своё значение колонки
                    string IPTest = ds1.Tables[0].Rows[k][3].ToString();
 
                    //закрываем соединение
                    conn.Close();
                    string Connect0 = "Data Source=" + IPTest;
                   // string Connect1 = ";Initial Catalog=" + DbTest;
                    string Connect2 = ";Persist Security Info=True; Provider=SQLOLEDB;User ID=sa;Password=mssql";
                    connection = new OleDbConnection(Connect0 + Connect2);
                    try
                    {
                        connection.Open();
                        OleDbDataAdapter adapter = new OleDbDataAdapter(str, connection);
                        adapter.Fill(dataSet, "Dbtabl");
                        //заполняем dataset
                        bindingSource = new BindingSource(dataSet, "Dbtabl");
                        //передаём данные из dataset в datagridview
                        dataGridView1.DataSource = bindingSource;
                        connection.Close();
                   }
                    catch
                    {
                        if (CheckServers(IPTest))
                        {
                            MessageBox.Show("Пинг есть, не удалось подключится к базе данных");
                        }
                        else
                        {
                            MessageBox.Show("Нет пинга до сервера!");
                        }
 
                    }
                    finally
                    {
                    
                        connection.Close();
 
                    }
                }
            }
        }
0
 Аватар для Adadjio
61 / 61 / 32
Регистрация: 30.07.2013
Сообщений: 178
15.08.2015, 12:28
rocker2003, для своего кода используй теги С#. Трудно читать твой код без тэгов.

Добавлено через 9 минут
Как вариант задай для каждого столбца в DataGridView формат отображения:
C#
1
dataGridView1..Columns["SomeCol"].DefaultCellStyle.Format = "dd.MM";
выведет дату в виде 01.01
для цифр:
C#
1
dataGridView1..Columns["SomeCol"].DefaultCellStyle.Format = "F";
Более подробно смотри тут
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.08.2015, 12:28
Помогаю со студенческими работами здесь

Как сделать заполнение таблицы из txt в datagridview
Как можно сделать так, чтобы из файла где все записано через пробел, чтобы автоматически заполнилась по нажатию кнопки в datagridview ...

Можно ли в QReport сделать заполнение отчета в цикле ?
Всем привет ! Вопрос такой : Можно ли в QReport сделать заполнение отчета не по запросу из БД, а просто в цикле ? Заранее спасибо !

Как сделать чтобы Заполнение одного значения формы вызывало заполнение множества других
Народ помогите чтобы при выставлении значения в ячейке формы КПКНазв (основана на табл.Договора) в форму проставлялись значения из таблицы...

BindingSource. dataGridView. Как сделать независимый фильтр для двух dataGridView?
Из Access данные импортируются в dataGridView В качестве источника данных используется один и тот же файл Acs-dtgrDB2003.mdb Каждый...

Подскажите как, чтобы программа проверяла как оценку. И как сделать один раз в цикле?
AUch.FIO:=Sg1.Cells; AUch.gr.fak:=Sg1.Cells; AUch.gr.kurs:=strtoint(Sg1.Cells); AUch.gr.spec:=Sg1.Cells; Try ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru