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

BindingSource игнорирует Filter

03.02.2014, 10:02. Показов 2806. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите, пожалуйста, справиться с BindingSource.Filter. Не могу понять, что я делаю не так, вот код:

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
BindingSource bs = new BindingSource();
        private void Form1_Load(object sender, EventArgs e)
        {
            sqlConnection.Open();
            sqlCommand.CommandText = "Select idNomer, nomer FROM nomer";
            SqlDataReader reader = sqlCommand.ExecuteReader();
            if (!reader.HasRows)
            {
                reader.Close();
                return;
            }
            else
            {
                bs.DataSource = reader;
                dataGrid.DataSource = bs;
                //bs.Filter = "idNomer = 5";
                reader.Close();
            }
        }
 
        private void buttonFind_Click(object sender, EventArgs e)
        {
            string f = "";
            if (checkBox.Checked)
            {
                if (textBox1.Text.Trim() != "") f += "idNomer = " + Convert.ToInt32(textBox1.Text);
            }
            if (f != "")
            bs.Filter = f;
        }
Прилагаю скрин запущенной программы (после нажатия кнопки Поиск). В режиме отладки проверяю значение bs.Filter, равно "idNomer = 4". Вроде правильно, а все равно в DataGrid выводит все существующие строки. Склоняюсь к тому, что студия (2010) глючит, и уже готова переустановить, но самое интересное в том, что на другой форме, созданной чуть ранее, такой же фильтр работает прекрасно. Объяснения этому найти не могу. Может кто что подскажет?
Миниатюры
BindingSource игнорирует Filter  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.02.2014, 10:02
Ответы с готовыми решениями:

Использование BindingSource.Filter
Ребята подскажите пожалуйста... Есть датагрид к ней подключена таблица и использую метод ниже для поиска...работает корректно... ...

Не работает Filter в BindingSource
Помогите разобраться. Нужно заставить BindingSource отображать только определенные записи, у которых задан идентификатор. Нужное значение...

DataCridView и BindingSource.Filter
Есть DataCridView с набором данных. В нем применяется фильтрация Запрос4BindingSource.Filter = строка для фильтра (Картинка с...

11
6 / 6 / 3
Регистрация: 16.01.2014
Сообщений: 69
03.02.2014, 18:07
может быть нужно фильтровать не idNomer а Nomer?

Добавлено через 15 минут
C#
1
2
bs.RemoveFilter();
bs.Filter = "Nomer =" + int.Parse(textBox1.Text);
0
0 / 0 / 0
Регистрация: 03.02.2014
Сообщений: 6
03.02.2014, 19:15  [ТС]
MindPower, у меня нет столбца Nomer, есть idNomer и nomer, но фильтр не работает ни по одному из них. И ошибки тоже не выдает, просто в таблицу выдаются все найденные записи
0
6 / 6 / 3
Регистрация: 16.01.2014
Сообщений: 69
03.02.2014, 21:02
если выдаются все записи значит в свойстве bs.Filter полюбому нет значения или вообще либо после "nomer=" скинь пример архивом, если сильно заморочил этот момент, у меня оч слабый уровень но уверен что пойму что к чему
0
0 / 0 / 0
Регистрация: 03.02.2014
Сообщений: 6
03.02.2014, 22:36  [ТС]
MindPower, в архиве прога и база данных. По идее, если распаковать на C:\, то подключение настраивать не придется. Сейчас еще раз всё перепроверила и даже заскринила. Если у тебя заработает на ура, то видимо дело в студии...
Миниатюры
BindingSource игнорирует Filter   BindingSource игнорирует Filter  
Вложения
Тип файла: rar тест.rar (181.1 Кб, 5 просмотров)
0
6 / 6 / 3
Регистрация: 16.01.2014
Сообщений: 69
04.02.2014, 04:00
в данном случае SqlDataReader нельзя использовать как источник данных для bindingSource, да и вообще всегда действую по след. схеме вроде того что ниже (все проверки и закрытия соединений не ставил):


C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
BindingSource bs = new BindingSource();
 
        private void Form1_Load(object sender, EventArgs e)
        {
            sqlConnection.Open();
            SqlDataAdapter adapter = new SqlDataAdapter();
            DataSet dataset = new DataSet();
            adapter.SelectCommand = new SqlCommand("Select idNomer, nomer FROM nomer", conn);
            adapter.Fill(dataset);
            bs.DataSource = dataset.Tables["nomer"];
            dataGrid.DataSource = bs;
        }
 
        private void buttonFind_Click(object sender, EventArgs e)
        {
            bs.Filter = "[nomer] =" + int.Parse(textBox1.Text);
        }
если хочешь фильтровать на вхождение подстроки в строку используй LIKE в фильтре
0
0 / 0 / 0
Регистрация: 03.02.2014
Сообщений: 6
04.02.2014, 21:06  [ТС]
MindPower, в данном случае дело не в SqlDataReader, это точно. У меня по такой схеме больше 10 таблиц на разных формах работает, из них на 2-х работает BindingSource.Filter. А еще на одной отказывается. Если есть желание разобраться, вот мой проект полностью, посмотри, пожалуйста) На главной форме все отлично, а вот на форме ListZakaz фильтр не действует... Про LIKE я знаю, проблема тоже не в этом
Вложения
Тип файла: rar КУРСАЧ.rar (1,021.7 Кб, 13 просмотров)
0
6 / 6 / 3
Регистрация: 16.01.2014
Сообщений: 69
04.02.2014, 21:40
ок, только ответ дам через часа 4 сейчас не могу посмотреть к сожалению
0
0 / 0 / 0
Регистрация: 03.02.2014
Сообщений: 6
04.02.2014, 22:07  [ТС]
MindPower, хорошо, заранее спасибо)
0
6 / 6 / 3
Регистрация: 16.01.2014
Сообщений: 69
04.02.2014, 23:46
Лучший ответ Сообщение было отмечено Jan4ik как решение

Решение

Девушка специально открыл MSDN и прочитал там следующее:

BindingSource.Filter свойство

Обычно используется в сложных сценариях привязки данных, свойство Filter позволяет просматривать подмножество DataSource. Лежащие в основе только списки, которые реализуют интерфейс фильтрации поддержки интерфейса IBindingListView
BindingSource.Filter

SqlDataReader же

C#
1
2
public class SqlDataReader : DbDataReader, 
    IDataReader, IDisposable, IDataRecord
как видно в описании класса

SqlDataReader
не поддерживает необходимый интерфейс IBindingListView поэтому работать у вас там фильтр не может нигде !!! Поэтому то что я написал выше правильно и делайте так как я написал выше, Dataset в качестве BindingSource.DataSource реализует необходимый вам механизм. Либо делайте выборку прямо в запросе, формируя запрос конкатенацией строк!

+ на вашем месте я бы собрал все на нескольких формах и реализовал общий механизм а не создавал ~30 форм на каждый случай ) но это уже не суть важно
1
0 / 0 / 0
Регистрация: 03.02.2014
Сообщений: 6
05.02.2014, 00:07  [ТС]
Всё, доперло) поняла, почему где-то фильтр работает, а где-то нет: работает там, где я (случайно, кстати) данные из SqlDataReader перезалила в DataTable, а потом уже DataTable использовала как DataSource для dataGridView. А в тех таблицах, где источник данных sqlDataReader, данные отображаются, но не фильтруются.
MindPower, большое спасибо за наводку
MSDN, кстати, по этой теме читала не один раз, но этот момент упустила(((

P.S.: уже успела переустановить MVS, неудивительно, что мне это не помогло)
0
6 / 6 / 3
Регистрация: 16.01.2014
Сообщений: 69
05.02.2014, 00:30
да не вопрос, был рад что чем то смог вам помочь у меня были похожие проблемы недавно
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.02.2014, 00:30
Помогаю со студенческими работами здесь

BindingSource.Filter в БД MySQL по времени
Доброго времени суток! Пытаюсь реализовать фильтр по времени в dataGridView BindingSource bind = new BindingSource(); DataSet DS =...

BindingSource.Filter и Application.Run
Появилась очень странная проблема, смысл которой я никак не могу понять. Делаю простой фильтр с использованием комбобокса в...

Фильтрация данных через BindingSource.Filter
Необходимо произвести поиск сразу по нескольким столбцам типа int и string. Данный запрос работает только со столбцами типа string. ...

BindingSource Filter - Сравнить два Int32
Надо сравнить два значения, оба в Int32. Этот код работает, сравнивает и правильно выдает, но теперь я немогу ничего добавить в БД,...

Ошибка Filter при использовании двух BindingSource
есть DataTable и 2 ComboBox Создаю 2 BindingSource(bs1 и bs2) на таблицу, привязываю каждый из них к своему боксу. Далее в процессе...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru