Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/40: Рейтинг темы: голосов - 40, средняя оценка - 4.85
0 / 0 / 0
Регистрация: 12.04.2015
Сообщений: 17

Вывод через ComboBox списка таблиц и их содержимого в DataGridView

20.05.2016, 17:15. Показов 7917. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно сделать приложение для баз данных(MS SQL). Мне нужно вывести список всех таблиц в Combobox, а затем при выборе из этого списка чтобы они появлялись в DataGridView. Я кое-как сделал это, но появилась проблема:
При выборе другой таблицы сохраняются столбцы предыдущей в DataGridView. Как мне это исправить?
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
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
        {
            
            if (comboBox1.Text == "Улица")
            {
                adapter = new SqlDataAdapter("SELECT * FROM Street", connection);
                adapter.Fill(ds);
                ds.Tables[0].Clear();
                adapter.Fill(ds);
 
                dataGridView1.DataSource = ds.Tables[0];   // отображение таблицв в сетке
               
            }
 
            else if (comboBox1.Text == "Здание")
            {
                adapter = new SqlDataAdapter("SELECT * FROM Building", connection);
                adapter.Fill(ds);
                ds.Tables[0].Clear();
                adapter.Fill(ds);
 
                dataGridView1.DataSource = ds.Tables[0];   // отображение таблицв в сетке
            }
 
            else if (comboBox1.Text == "Квартира")
            {
 
                adapter = new SqlDataAdapter("SELECT * FROM Flat", connection);
 
                adapter.Fill(ds);
                ds.Tables[0].Clear();
                adapter.Fill(ds);
 
                dataGridView1.DataSource = ds.Tables[0];   // отображение таблицв в сетке
            }
 
        }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.05.2016, 17:15
Ответы с готовыми решениями:

Подскажите, как сделать выборку таблиц из combobox в DataGridView
Имеется 7 таблиц в SQL Server, 1 combobox, где есть выбор данных таблиц. Нужно, чтобы в DataGridView подгружалась таблица, выбранная в...

Вывод содержимого Dataset и Datatable в datagridview
Ситуация такая есть нормально работающий фрагмент кода SqlCommand cmd = new SqlCommand("select * from Клиент", conn); ...

Вывод таблиц в Combobox
Может быть есть такая тема или я не по теме, то скиньте куда кидать Есть база данных, подключение через oledb, есть код, при...

3
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
20.05.2016, 18:57
Перед загрузкой данных вызывайте dataGridView1.Columns.Clear()
0
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
20.05.2016, 19:43
Цитата Сообщение от rutherdor Посмотреть сообщение
Нужно сделать приложение для баз данных
rutherdor, в мусорку эту портянку из if-else. Вот пример для OleDb, переделайте под Ms 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
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;
using System.IO;
using System.Data.OleDb;
 
namespace WindowsFormsApplication2 {
    public partial class Form1 : Form {
        public Form1() {
            InitializeComponent();
            this.Load += new EventHandler(Form1_Load);
            cmbTables.SelectedValueChanged += new EventHandler(cmbTables_SelectedValueChanged);
        }
 
        void cmbTables_SelectedValueChanged(object sender, EventArgs e) {
            UpdateView(cmbTables.Text);
        }
 
        void Form1_Load(object sender, EventArgs e) {
            cmbTables.Items.AddRange(Enum.GetNames(typeof(Tables)));
        }
 
        void UpdateView(string tableName) {
            try {
                tablesGridView.DataSource = null;
                tablesGridView.DataSource = DbHelper.GetTableByName(tableName);
            }
            catch (Exception ex) {
                MessageBox.Show(ex.Message, "Error");
            }
        }
    }
    public class DbHelper {
        static string CONNECT_STR = string.Format("Provider=Microsoft.Jet.OLEDB.4.0; Data Source={0}",
            Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "database.mdb"));
 
        public static DataTable GetTableByName(string tableName) {
            DataTable dt = new DataTable(tableName);
            string command = string.Format("SELECT * FROM {0}", tableName);
            using (OleDbConnection cnn = new OleDbConnection(CONNECT_STR)) {
                cnn.Open();
                using (OleDbCommand cmd = new OleDbCommand(command, cnn)) {
                    using (OleDbDataReader dr = cmd.ExecuteReader()) {
                        dt.Load(dr);
                    }
                }
            }
            return dt;
        }
    }
    enum Tables {
        Buildings,
        Flats,
        Streets
    }
}
0
0 / 0 / 0
Регистрация: 12.04.2015
Сообщений: 17
20.05.2016, 20:34  [ТС]
Igr_ok, пробовал,не помогает

Добавлено через 43 минуты
insite2012, спасибо за это, но я плохо разбираюсь(
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.05.2016, 20:34
Помогаю со студенческими работами здесь

Подскажите ComboBox добавление таблиц DataGridView
Подскажите как организовать: при выборе названия таблиц из ComboBox нужно добавлять DataGridView с данными таблицы в "поле"*,...

Вывод списка в ComboBox зависимости от выбора в другом ComboBox. C++
Вывод списка в ComboBox зависимости от выбора в другом ComboBox. Например, студент выбирает группу, а после предмет по своей...

Вывод содержимого combobox в richtextbox
В C# я пока что новичок. Поэтому как это сделать не совсем то и понимаю... Мне нужно содержимое Комбобокса записать в Ричтекстбокс В...

Вывод содержимого нскольких таблиц
Подскажите в какой компонент можно вывести содержимое нескольких таблиц (в таблицах полей более 20) в не которых таблицах может быть по...

combobox, запись из него в БД и вывод списка из БД в combobox
Уважаемые форумчане подскажите как сделать так что б в таблицу predmet (2 поля id_predmet-счетчик, Nazvanie_predmeta-текстовый) из ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru