Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/27: Рейтинг темы: голосов - 27, средняя оценка - 4.52
45 / 45 / 7
Регистрация: 28.05.2009
Сообщений: 87

Не могу прикрутить bindingnavigator к grid, которая связана с другой grid

29.06.2010, 12:33. Показов 5276. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
вот код, если бы grid не были связаны то и проблем бы не было. а тут никак не получается.
нужно чтобы binding навигатор относился к dataGridView2

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
    OleDbConnection conn = new OleDbConnection("Provider=SQLNCLI.1;Data Source=192.168.3.1;User ID=sa;Initial Catalog=pay");
            DataSet DS = new DataSet();
            //1 таблица
            string sql1 = "select * from schet";
            OleDbDataAdapter dataAdapter1 = new OleDbDataAdapter(sql1, conn);
            dataAdapter1.Fill(DS, "Счетчик");
            //2 таблица
            string sql2 = "select top 5000 * from tpay";
            OleDbDataAdapter dataAdapter2 = new OleDbDataAdapter(sql2, conn);
            dataAdapter2.Fill(DS, "Платежи");
            //**********устанавливаем связь**********************************
            DataRelation rel = new DataRelation("связь", DS.Tables["Счетчик"].Columns["sch"], DS.Tables["Платежи"].Columns["tippl"], true);
            DS.Relations.Add(rel); // добавляем связь
            DataViewManager dsview = DS.DefaultViewManager;
 
            
            
            BindingSource bs = new BindingSource();
            bs.DataMember = "Счетчик, Счетчик.связь";
 
 
 
 
            dataGridView1.DataSource = bs; 
            dataGridView1.DataMember = "Счетчик.связь";
            dataGridView2.DataSource = bs; 
            dataGridView2.DataMember = "Счетчик";
 
//            bs.DataMember = "Счетчик"; //- если это раскоментировать навигатор работает но не перемещается по dbgrid
            bindingNavigator2.BindingSource =bs ;
1
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.06.2010, 12:33
Ответы с готовыми решениями:

Как в Data Grid изменять данные? Data Grid связана с sql БД
(WPF) В форме есть Data Grid и 3 кнопки (Изменить, Сохранить, Удалить). Как сделать чтоб эти кнопки работали так как заявлено?

В стиле для элемента Grid использовать другой Grid
Пытаюсь создать вот такой стиль для Grid <Style x:Key="CrosswalkHorizontal" TargetType="Grid"> <Setter...

Возможно ли задать в XAML число строк и столбцов Grid сразу, без исп <Grid.ColumnDefinitions> и <Grid.RowDefinnitions>?
Возможно ли задать в XAML число строк и столбцов Grid сразу, без исп &lt;Grid.ColumnDefinitions&gt; и &lt;Grid.RowDefinnitions&gt;?

5
2 / 2 / 0
Регистрация: 17.09.2009
Сообщений: 7
02.07.2010, 12:26
У меня такая же проблема!!!
Вот пример моего кода:

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
ConnectionToDB = null;
                    ConnectionToDB = new OleDbConnection(); //TODO: Может выделять под него память один раз?
                    ConnectionToDB.ConnectionString = ConnectionString;
                    //Делегат EventHandler связывает метод-обработчик conn_Disposed c событием Disposed объекта conn
                    ConnectionToDB.Disposed += new EventHandler(ConnectionDisposed);
                    //Делегат StateChangeEventHandler связывает метод-обработчик conn_StateChange с событием StateChange объекта conn
                    ConnectionToDB.StateChange += new StateChangeEventHandler(ConnectionStateChange);
 
                    ConnectionToDB.Open();
 
                    OleDbDataAdapter UserDataAdapter = new OleDbDataAdapter("SELECT * FROM Users", ConnectionToDB);
                    OleDbDataAdapter OrderDataAdapter = new OleDbDataAdapter("SELECT * FROM Orders", ConnectionToDB);
 
                    DataSet _DataSet = new DataSet();
                    UserDataAdapter.Fill(_DataSet, "Users");
                    OrderDataAdapter.Fill(_DataSet, "Orders");
 
                    DataColumn dc_tUsers_fID = _DataSet.Tables["Users"].Columns["ID"];
                    DataColumn dc_tOrders_fUserID = _DataSet.Tables["Orders"].Columns["UserID"];
                    DataRelation dataRelation = new DataRelation("OrdersRelation", dc_tUsers_fID, dc_tOrders_fUserID);
                    _DataSet.Relations.Add(dataRelation);
 
                    UserdataGridView.DataSource = _DataSet.DefaultViewManager;
                    UserdataGridView.DataMember = "Users";
                    
                    OrderdataGridView.DataSource = _DataSet.DefaultViewManager;
                    OrderdataGridView.DataMember = "Users.OrdersRelation";
 
                    UserbindingNavigator.BindingSource = new BindingSource(_DataSet, "Users");
                    OrderbindingNavigator.BindingSource = new BindingSource(_DataSet, "Orders");
0
45 / 45 / 7
Регистрация: 28.05.2009
Сообщений: 87
03.07.2010, 01:50  [ТС]
N0mad, как я понимаю UserbindingNavigator тоже по UserdataGridView не перемещается?
я решил это по другому
наколхозил конечно но работает как часы. Заполняем первую таблицу а потом на событие CurrentCellChanged вешаем заполнение подчиненной таблицы, навигатор без проблем прикручивается. Вот код:
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
 //1 таблица
            string sql1 = "select * from schet";
          //  OleDbDataAdapter dataAdapter1 = new OleDbDataAdapter(sql1, conn);
            dataAdapter1.Fill(DS, "Счетчик");
            bs.DataSource = DS;
            bs.DataMember = "Счетчик";
            dataGridView2.DataSource = bs;
            bindingNavigator2.BindingSource = bs;
 
//---------------------------------------------------
//а вот событие
private void dataGridView2_CurrentCellChanged(object sender, EventArgs e)
        {
            //При изменении позиции в 1 dbGRid заполняем второй
            //######################################################################
            string sql2 = "select top 500 * from tpay where tippl=?";
            
            DataRowView eee = bs.Current as DataRowView;
            dataAdapter.SelectCommand = new OleDbCommand(sql2, conn);
           
            //теперь параметры для select
            dataAdapter.SelectCommand.Parameters.Add("tippl", OleDbType.Char, 0, "tippl").Value = Convert.ToString(eee["sch"]);
                            
            try
            {
                DS.Tables["Платежи"].Clear();
            }
            catch { }
            dataAdapter.Fill(DS, "Платежи");
            dataGridView1.DataSource = DS.Tables["Платежи"];
            //#######################################################################
          
          
        }
0
2 / 2 / 0
Регистрация: 17.09.2009
Сообщений: 7
05.07.2010, 12:17
Вот! Сделал всё проще.


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
77
private bool ConnectToDataBase()
        {
            if (IsConnectedToDatabase == false)
            {
                try
                {
                    ConnectionToDB = null;
                    ConnectionToDB = new OleDbConnection(); //TODO: Может выделять под него память один раз?
                    ConnectionToDB.ConnectionString = ConnectionString;
                    //Делегат EventHandler связывает метод-обработчик conn_Disposed c событием Disposed объекта conn
                    ConnectionToDB.Disposed += new EventHandler(ConnectionDisposed);
                    //Делегат StateChangeEventHandler связывает метод-обработчик conn_StateChange с событием StateChange объекта conn
                    ConnectionToDB.StateChange += new StateChangeEventHandler(ConnectionStateChange);
 
                    ConnectionToDB.Open();
 
                    DataSet _DataSet = new DataSet();
 
                    OleDbDataAdapter UserDataAdapter = new OleDbDataAdapter("SELECT * FROM Users", ConnectionToDB);
                    OleDbDataAdapter OrderDataAdapter = new OleDbDataAdapter("SELECT * FROM Orders", ConnectionToDB);
 
                    UserDataAdapter.Fill(_DataSet, "Users");
                    OrderDataAdapter.Fill(_DataSet, "Orders");
 
                    DataColumn dc_tUsers_fID = _DataSet.Tables["Users"].Columns["ID"];
                    DataColumn dc_tOrders_fUserID = _DataSet.Tables["Orders"].Columns["UserID"];
                    DataRelation dataRelation = new DataRelation("FK_Orders_Users", dc_tUsers_fID, dc_tOrders_fUserID);
                    _DataSet.Relations.Add(dataRelation);
 
                    BindingSource UserBindingSource = new BindingSource(_DataSet, "Users");
                    BindingSource OrderBindingSource = new BindingSource(UserBindingSource, "FK_Orders_Users");
 
 
                    UserdataGridView.DataSource = UserBindingSource;
                    OrderdataGridView.DataSource = OrderBindingSource;
 
                    UserbindingNavigator.BindingSource = UserBindingSource;
                    OrderbindingNavigator.BindingSource = OrderBindingSource;
 
                    UserdataGridView.Columns[0].HeaderText = "ИД";
                    UserdataGridView.Columns[1].HeaderText = "Фамилия";
                    UserdataGridView.Columns[2].HeaderText = "Имя";
                    UserdataGridView.Columns[3].HeaderText = "Отчество";
                    UserdataGridView.Columns[4].HeaderText = "Телефон";
                    
                    OrderdataGridView.Columns[0].HeaderText = "ИД";
                    OrderdataGridView.Columns[1].HeaderText = "ИД пользователя";
                    OrderdataGridView.Columns[2].HeaderText = "Тип заказа";
                    OrderdataGridView.Columns[3].HeaderText = "Номер заказа";
                    OrderdataGridView.Columns[4].HeaderText = "Дата заказа";
                    OrderdataGridView.Columns[5].HeaderText = "Описание";
 
                }
                catch (System.InvalidOperationException Ex)
                {
                    // Обработать исключение
                    MessageBox.Show("Невозможно подключиться к базе данных!", "Ошибка",
                        MessageBoxButtons.OK, MessageBoxIcon.Error);
                    return false;
                }
                catch (System.Data.OleDb.OleDbException Ex)
                {
                    // Обработать исключение
                    MessageBox.Show("Невозможно подключиться к базе данных!", "Ошибка",
                        MessageBoxButtons.OK, MessageBoxIcon.Error);
                    return false;
                }
                catch (System.Exception Ex)
                {
                    // Обработать исключение
                    MessageBox.Show("Невозможно подключиться к базе данных!\r\nИсключение: " + Ex.Message, "Ошибка",
                        MessageBoxButtons.OK, MessageBoxIcon.Error);
                    return false;
                }
            }
            return true;
        }
1
 Аватар для nio
6050 / 3460 / 336
Регистрация: 14.06.2009
Сообщений: 8,136
Записей в блоге: 2
05.07.2010, 20:26
slayer, N0mad, пожалуй, в bindingNavigator следует указывать не конкретно dataGridView, а BindingSource, с которым этот dataGridView связан. Таким образом получается, что dataGridView и bindingNavigator между собой не связаны, но связаны с одним BindingSource, который в свою очередь связан с адаптером.
Тогда все работает нормально
0
45 / 45 / 7
Регистрация: 28.05.2009
Сообщений: 87
06.07.2010, 09:17  [ТС]
N0mad, Спасибо! супер решение!

Добавлено через 19 минут
Цитата Сообщение от nio Посмотреть сообщение
следует указывать не конкретно dataGridView, а BindingSource, с которым этот dataGridView связан
дык мы так и указывали
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.07.2010, 09:17
Помогаю со студенческими работами здесь

А кроме Data Grid есть еще какой-нибудь Grid?
Вопрос конечно тупой, но что-то смотрю и не вижу. Или может не туда смотрю. Одним словом торможу. Опять же раньше был в VB такой...

CSS grid (display: grid) как расположить блоки?
Пожалуйста подскажите как мне с помощью display grid рассположить блоки как на скриншоте

Как изменить Grid.Row и Grid.Column в элементе
как переместить кнопку из одной ячейки в другую при нажатии на нее или как поменять содержимое ячеек местами также при нажатии на кнопку ...

Неправильная ширина в Css Grid (grid-template-columns)
По высоте все нормально, но ширину никак не додумаюсь как выставить как на макете в итоге получил в макете должно быть так ...

Сброс параметров Grid.Row Grid.Column
Решил попробовать Catel и обнаружил что при вводе данного свойства он сбрасывается при компиляции. XAML Code файла MainWindow ...


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

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