Форум программистов, компьютерный форум, киберфорум
Наши страницы
C# Windows Forms
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
andrey-m11
18 / 18 / 6
Регистрация: 25.03.2013
Сообщений: 110
1

Как правильно отображать данные в DataGridViewComboBoxColumn?

25.08.2014, 18:36. Просмотров 1401. Ответов 5
Метки нет (Все метки)

привет всем!!!
Создал таблице DataGridView
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
 public DataGridViewComboBoxColumn driveComboBox2;
 public void LoadDataGrid2()//Рисуем таблицу 
        {
driveComboBox2= 
            string command = "select idApplication, RegistrApplication.DateTimeA as Дата, RegistrApplication.Телефон, RegistrApplication.Из ,RegistrApplication.В  from RegistrApplication ";
            dataGridView2.DataSource = null;
            dataGridView2.Columns.Clear(); // <-- clear columns
            dataGridView2.DataSource = loadDataGrid(SQLcomm(command));
            dataGridView2.AllowUserToAddRows = false; // remove the null line
            dataGridView2.ReadOnly = true;
            dataGridView2.Columns[0].Visible = false;
            dataGridView2.Columns[1].Width = 80;
            dataGridView2.Columns[2].Width = 109;
            dataGridView2.Columns[3].Width = 250; 
            dataGridView2.Columns[4].Width = 250;
            // drive ComboBox2 to datagridview2
            driveComboBox2.HeaderText = "Водитель";
            driveComboBox2.DefaultCellStyle.BackColor = Color.Green;
            driveComboBox2.Width = 100;
            dataGridView2.Columns.Add(driveComboBox2);
            SQLClose();
надо заполнить список items driveComboBox2
C#
1
2
3
4
5
SqlDataReader reader = SQLcomm("select idDriver from driver" ).ExecuteReader();
                while (reader.Read())
                {
                    ????????.(reader["idDriver"]);
                }
как обычный ComboBox
C#
1
2
3
4
5
6
7
8
9
10
11
12
public void ListComBox(ComboBox CBox, string tabl, string date)//заполнение 
        {
           
                CBox.Items.Clear();
                CBox.Text = "";
                SqlDataReader reader = SQLcomm("select replace("+date+",' ','') AS "+date+ " from " + tabl).ExecuteReader();
                while (reader.Read())
                {
                    CBox.Items.Add(reader[date]);
                }
 
            }
не получается, список не открывается ComboBox в таблице не реагирует
подскажите что делать...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.08.2014, 18:36
Ответы с готовыми решениями:

Графики, по оси X отображать данные типа DateTime
Мне нужно, чтобы по оси X отображались данные типа DateTime Данные берутся из...

Каким образом отображать данные из базы данных на форме?
Здравствуйте. Не знаю с чего начинать, поэтому хочу спросить. Допустим, нужно...

Компонент webBrowser должен отображать данные при старте программы
Как сделать так, чтобы компонент webBrowser отображал сразу при старте...

Как создается DataGridViewComboBoxColumn?
Доброго времени суток! Есть программа, в которой нужно вывести таблицу БД...

Как правильно записать данные в List?
Пишу программу для создания тестов. Первый класс class Answer { ...

5
Hemicide
118 / 111 / 62
Регистрация: 27.07.2014
Сообщений: 225
25.08.2014, 19:10 2
andrey-m11, для того, чтобы твой ComboBox открывался, колонка в DataGridView в которой он располагается, должна содержать такие-же значения, с одним и тем-же ключом. DataGridViewComboBoxColumn.ValueMember
Здесь ComboBox не самостоятельный элемент, а его содержимое полностью зависит от содержимого колонки
0
andrey-m11
18 / 18 / 6
Регистрация: 25.03.2013
Сообщений: 110
25.08.2014, 19:32  [ТС] 3
Hemicide, а пример можно?? понимаю о чем речь но пока сложно сообразить
0
Hemicide
118 / 111 / 62
Регистрация: 27.07.2014
Сообщений: 225
25.08.2014, 20:07 4
Цитата Сообщение от andrey-m11 Посмотреть сообщение
C#
1
2
3
driveComboBox2.HeaderText = "Водитель";
driveComboBox2.DefaultCellStyle.BackColor = Color.Green;
driveComboBox2.Width = 100;
Ты забыл для driveComboBox2 DataSource указать, из которого ComboBox брал бы данные.
А так-же в driveComboBox2.ValueMember = "поле с ID водителей", а в driveComboBox2.DisplayMember = "посе с именами водителей"

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
69
70
71
72
73
74
75
76
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
 
namespace WindowsFormsApplication1
{
    public partial class Form1 : Form
    {
 
        DataTable DriversTable;
        DataTable MainDrivers;
 
        public Form1()
        {
            InitializeComponent();
        }
 
        private void Form1_Load(object sender, EventArgs e)
        {
            Initialize_DriversTable();
            this.dataGridView1.AutoGenerateColumns = false;
            this.dataGridView1.DataSource = MainDrivers;
 
            using (DataGridViewComboBoxColumn column = new DataGridViewComboBoxColumn())
            {
                column.DataSource = DriversTable;
                column.ValueMember = "ID";
                column.DisplayMember = "Name";
                column.Name = "Drivers";
                column.HeaderText = "Водители";
                column.DataPropertyName = "Name";
                column.SortMode = DataGridViewColumnSortMode.NotSortable;
                column.Width = 240;
                this.dataGridView1.Columns.Add(column);
            }
 
        }
 
        private void Initialize_DriversTable()
        {
 
            //Главная таблица, которая является ресурсом для всего dataGridView
            MainDrivers = new DataTable();
            MainDrivers.Columns.Add(new DataColumn("IDDrivers", typeof(Guid)));
 
 
            //Таблица для колонки с водителями
            DriversTable = new DataTable();
            DriversTable.Columns.Add(new DataColumn("ID", typeof(Guid)));
            DriversTable.Columns.Add(new DataColumn("Name", typeof(string)));
 
            DataRow dr = null;
 
            dr = DriversTable.NewRow();
            dr["ID"] = Guid.NewGuid();
            dr["Name"] = "Вова";
            DriversTable.Rows.Add(dr);
 
            dr = DriversTable.NewRow();
            dr["ID"] = Guid.NewGuid();
            dr["Name"] = "Петя";
            DriversTable.Rows.Add(dr);
 
            dr = DriversTable.NewRow();
            dr["ID"] = Guid.NewGuid();
            dr["Name"] = "Саша";
            DriversTable.Rows.Add(dr);
 
        }
    }
}
1
andrey-m11
18 / 18 / 6
Регистрация: 25.03.2013
Сообщений: 110
27.08.2014, 16:13  [ТС] 5
Hemicide, спасибо очень ценная информация... но немного не то ... сам разобрался просто
C#
1
 dataGridView2.ReadOnly = true;//запрет редактирования
и потому не открывается.
.убрал и заполнил так..
C#
1
2
3
4
5
6
7
8
9
10
11
12
             string command2 = "select idDriver from Drivers";
            twoDriveComboBox2 = new DataGridViewComboBoxColumn();
            twoDriveComboBox2.HeaderText = "Позывной";
            twoDriveComboBox2.DefaultCellStyle.BackColor = Color.Yellow;
            twoDriveComboBox2.Width = 300;
            SqlDataReader reader = SQLcomm(command2).ExecuteReader();
            while (reader.Read())
            {
                twoDriveComboBox2.Items.Add(reader["Позывной"]);
            }
            
            dataGridView2.Columns.Add(twoDriveComboBox2);
все работает...
0
Hemicide
118 / 111 / 62
Регистрация: 27.07.2014
Сообщений: 225
27.08.2014, 16:17 6
Цитата Сообщение от andrey-m11 Посмотреть сообщение
C#
1
dataGridView2.ReadOnly = true;//запрет редактирования
Да... я тоже внимания не обратил...
0
27.08.2014, 16:17
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.08.2014, 16:17

Как правильно перехватывать данные из консоли
Доброе время суток уважаемые ! Вот перехватываю данные из консоли: using...

C# и COM порт: как правильно прочитать данные
Здравствуйте. Написал простой код и не могу понять почему не работает. Кто...

Как правильно записывать данные в файл?
Пишу в файл построчно. Файл получается достаточно большой. Сейчас он выходит в...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru