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

Выборка из datagridview

05.03.2015, 09:20. Показов 2017. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Необходима вожможность выборки данных из dataGridView в нее саму вывожу таким кодом.
C#
1
2
3
4
5
6
7
8
9
10
SetConnection();
            con.Open();
 
            DataSet data_set = new DataSet();
            SQLiteCommand sql_command = con.CreateCommand();
            string command_string = "SELECT id_stud,famil,nam,otch,date,pas,prop,departament.NAME,status.NAME,facultet.NAME,course.name,spetial.NAME,start,end,prik,rem FROM student LEFT JOIN facultet,departament,status,spetial,course ON student.fac = facultet.ID_FACULTET AND student.depa = departament.ID_DEPARTAMENT AND student.cours = course.id_course AND student.spetial = spetial.ID_SPETIAL AND student.stat = status.ID_STATUS;";
            SQLiteDataAdapter ad = new SQLiteDataAdapter(command_string, con);
            SQLiteCommandBuilder cmd = new SQLiteCommandBuilder(ad);
            ad.Fill(data_set);
            dataGridView1.DataSource = data_set.Tables[0].DefaultView;
Хотелось бы чтобы при выборе значения в нескольких разных комбобоксах выводились соответствующие данные.
В данный момент сделано что при выборе значения в 1 комбобоксе идет новый запрос в базу и выводиться только то значение которое выбрано
C#
1
2
3
4
5
6
7
8
9
10
11
private void comboBox6_SelectionChangeCommitted(object sender, EventArgs e)
        {
            SQLiteConnection conn = new SQLiteConnection("Data Source=voenka.db; Version=3;");
            conn.Open();
            SQLiteCommand sqlCom = new SQLiteCommand("SELECT id_stud,famil,nam,otch,date,pas,prop,departament.NAME,status.NAME,facultet.NAME,course.name,spetial.NAME,start,end,prik,rem FROM student LEFT JOIN facultet,departament,status,spetial,course ON student.fac = facultet.ID_FACULTET AND student.depa = departament.ID_DEPARTAMENT AND student.cours = course.id_course AND student.spetial = spetial.ID_SPETIAL AND student.stat = status.ID_STATUS WHERE (spetial LIKE '" + comboBox6.SelectedValue.ToString() + "');", conn);
            SQLiteDataReader dr = sqlCom.ExecuteReader();
            DataTable dt = new DataTable();
            dt.Load(dr);
            dataGridView1.DataSource = dt;
        
        }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.03.2015, 09:20
Ответы с готовыми решениями:

DatagridVIew выборка данных
Здравствуйте, мне нужно заполнить ДатуГрид данными из БД, которые бы соответствовали условию - в таблице есть три поля которые с одинаковым...

Выборка в datagridview с переменной
Добрый день! Подскажите, пожалуйста такой момент. У меня есть приложение windows forms. В ней существует несколько связанных между форм. ...

Выборка из datagridview в listBox
Здравствуйте. Нужно сделать что бы из datagridview можно было выбрать одну строку(выделенную) и по нажатию на кнопку она переносилась в...

3
27 / 27 / 10
Регистрация: 18.08.2014
Сообщений: 212
05.03.2015, 11:25
Для того что бы сделать фильтр для dataGridView1 вам необходимо к источнику данных сделать LINQ запрос и присвоить результат источнику данных dataGridView1.
Я реализовывал так:
GridView заполнялся из коллекции.
ТекстБокс событие ввода текста -> Linq запрос к коллекции (where a=textbox.text) -> результат присваивал ИтемСурст моего GridView

И нет необходимости постоянно долбится в БД
0
1 / 1 / 1
Регистрация: 14.07.2011
Сообщений: 117
05.03.2015, 12:34  [ТС]
Немогли бы вы показать пример кода
0
27 / 27 / 10
Регистрация: 18.08.2014
Сообщений: 212
05.03.2015, 15:22
Есть ObservableCollection<Acount> acountCollection, который присваивается ListView
XML
1
2
3
4
5
6
7
8
9
10
        <ListView x:Name="OutData" ItemsSource="{Binding acountCollection}">
            <ListView.View>
                <GridView>
                    <GridView.Columns>
                        <GridViewColumn DisplayMemberBinding="{Binding Id}"></GridViewColumn>
                        <-- тут столбцы -->
                    </GridView.Columns>
                </GridView>
            </ListView.View>
        </ListView>
Есть несколько TextBox`ов
XML
1
2
        <TextBox  Name="idFilter" TextChanged="LinqFilter_TextChanged"/>
       <--Количество TextBox равно количеству столбцов ListView-->
на каждый текстбокс повешено событие
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
private void LinqFilter_TextChanged(object sender, System.Windows.Controls.TextChangedEventArgs e)
        {
            if (idFilter.Text != string.Empty | tbx7Filter.Text != string.Empty | InstLoc.Text != string.Empty | Brand.Text != string.Empty
                | Model.Text != string.Empty | Ramis.Text != string.Empty | Description.Text != string.Empty | Description.Text != string.Empty
                | FioName.Text != string.Empty | DataInst.Text != string.Empty)
            {
                var filtered = from sort in acountCollection
                               where sort.Id.IndexOf(idFilter.Text, StringComparison.OrdinalIgnoreCase) >= 0 &
                               sort.Pole6.IndexOf(tbx7Filter.Text, StringComparison.OrdinalIgnoreCase) >= 0 &
                               sort.Pole1.IndexOf(InstLoc.Text, StringComparison.OrdinalIgnoreCase) >= 0 &
                               sort.Pole2.IndexOf(Brand.Text, StringComparison.OrdinalIgnoreCase) >= 0 &
                               sort.Pole3.IndexOf(Model.Text, StringComparison.OrdinalIgnoreCase) >= 0 &
                               sort.Pole4.IndexOf(Ramis.Text, StringComparison.OrdinalIgnoreCase) >= 0 &
                               sort.Pole5.IndexOf(Description.Text, StringComparison.OrdinalIgnoreCase) >= 0 &
                               sort.Fio.IndexOf(FioName.Text, StringComparison.OrdinalIgnoreCase) >= 0 &
                               sort.Fdata.IndexOf(DataInst.Text, StringComparison.OrdinalIgnoreCase) >= 0
                               orderby sort.Id
                               select sort;
                OutData.ItemsSource = filtered;
                PrintAcount = filtered.ToList();
            }
            else
            {
                OutData.ItemsSource = acountCollection;
            }
        }
Смысл фильтра заключается в том что фильтрация происходит по последовательности символов, при внесении в любой из TextBox хотя бы одного символа, при этом фильтруется сразу по нескольким столбцам.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.03.2015, 15:22
Помогаю со студенческими работами здесь

DataGridView выборка из разных таблиц
Имеем вот такой &quot;датагрид&quot; (фото вложено), вытянутый из таблицы, допустим, Payments. Задача вместо колонок &quot;ID Клиента&quot; и...

Выборка из datagridview
Всем здравствуйте. Есть datagridview следующего вида: необходимо разбить эту таблицу на несколько , т.е. в данном случае будет...

Выборка данных из DataGridView
Добрый день. Господа, подскажите направление мысли. Есть грид. В первом столбце - некие вещества, в последующих - их характеристики....

Выборка из DataGridView по ФИО с использованием RowFilter
Столкнулся с проблемой. Есть огромная выборка из БД в DataGridView (23 000 строк). Также есть поле поиска, куда вводится ФИО (может...

Выборка даты из БД и отображение в DataGridView в определенном формате
Доброго времени суток, уважаемые! Подскажите пожалуйста решение) застопорился в выводе даты в dataGridView. Суть такая: получаю...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
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