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

Не связывает 2 таблицы из базы Данных, работа Windows Form

11.05.2010, 00:44. Показов 1285. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет Всем!Я не знал куда написать эту тему так как это и Базы даных и Windows Form??!!!
Проблема собственно в том что при нажатии кнопки связать(тоесть в Комбо боксах мы записываем таблицу и поля по которым мы собираемся связать таблицы) НО выдает такую ошибку
FillShema : Select.Command.Connection property has not be initialized.

вот обработчик события

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
private void Do_swjaz_Click(object sender, EventArgs e)
        {
            try
            {
                ds_2_rel = new DataSet();
                DataTable table1 = new DataTable("First");//создаём 2 таблици
                DataTable table2 = new DataTable("Second");
                ds_2_rel.Tables.Add(table1);//помещаем их в обьект ds_2_rel
                ds_2_rel.Tables.Add(table2);
                ad_2 = new SqlDataAdapter("select * from " + SwjazBox1.Text, con_2);
                ad_2.FillSchema(ds_2_rel.Tables[0], SchemaType.Source);
                ad_2.Fill(ds_2_rel.Tables[0]);//заполняем 1-ю таблицу
                ad_2 = new SqlDataAdapter("select * from " + SwjazBox2.Text, con_2);
                ad_2.FillSchema(ds_2_rel.Tables[1], SchemaType.Source);
                ad_2.Fill(ds_2_rel.Tables[1]);//заполняем 2-ю таблицу
                DataColumn par = ds_2_rel.Tables[0].Columns[KBox1.Text];
                DataColumn child = ds_2_rel.Tables[1].Columns[KBox2.Text];
                //делаем связь через столбцы
                DataRelation re_2 = new DataRelation("FK_" + SwjazBox1.Text + "_" + SwjazBox2.Text, par, child, true);
                ds_2_rel.Relations.Add(re_2);//добавляем эту всязь в ds_2_rel
                dGV5.DataSource = ds_2_rel;
                dGV5.DataMember = ds_2_rel.Tables[0].ToString();
                for (int i2 = 0; i2 < dGV5.ColumnCount; i2++) { dGV5.Columns[i2].Width = 65; }
                dGV4.DataSource = ds_2_rel;
                dGV4.DataMember = ds_2_rel.Tables[1].ToString();
                for (int i2 = 0; i2 < dGV4.ColumnCount; i2++) { dGV4.Columns[i2].Width = 65; }
            }
            catch (Exception ex) { MessageBox.Show(ex.Message.ToString()); }
 
        }
Он даже не пытаеться чето вывести(((
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.05.2010, 00:44
Ответы с готовыми решениями:

Windows Form и базы данных Access
Здравствуйте) Я никогда не работала в Visual Studio и не знаю C#. Помогите пожалуйста!!! Мне надо произвести выборку данных из базы...

Windows Form Visual Basic базы данных
Надо сделать так, чтобы после заполнения Textbox-оф, после нажатия кнопки появлялась соответсвенно заполненная строчка в БД. Но ничего не...

Какое свойство TDBEdit связывает его с конкретным полем таблицы
Всем здравствуйте. Есть база данных MSAccess с единственной таблицей Таблица имеет индексированное поле и несколько строковых полей ...

3
137 / 133 / 20
Регистрация: 03.02.2009
Сообщений: 608
11.05.2010, 09:27
а где сам con_2?
0
0 / 1 / 1
Регистрация: 10.05.2010
Сообщений: 46
11.05.2010, 17:25  [ТС]
Цитата Сообщение от virus_system Посмотреть сообщение
а где сам con_2?
а вот собственно и con_2

C#
1
2
3
4
5
6
            con_2 = new SqlConnection();
 
con_2.ConnectionString =
 @"server =COMP\SQLEXPRESS;" +
     "integrated security=true;" +
        "database =my_lab;";
0
1 / 1 / 1
Регистрация: 22.02.2010
Сообщений: 3
12.05.2010, 10:00
Вот так работает. В кнопке

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
 using(SqlConnection con_2 = new SqlConnection())
            {
                con_2.ConnectionString = @"Data Source = localhost; Initial Catalog = my_lab; Integrated Security = SSPI";
                con_2.Open();
 
                try
                {
                    ds_2_rel = new DataSet();
                    DataTable table1 = new DataTable("First");//создаём 2 таблици
                    DataTable table2 = new DataTable("Second");
                    ds_2_rel.Tables.Add(table1);//помещаем их в обьект ds_2_rel
                    ds_2_rel.Tables.Add(table2);
                    ad_2 = new SqlDataAdapter("select * from " + SwjazBox1.Text, con_2);
                    ad_2.FillSchema(ds_2_rel.Tables[0], SchemaType.Source);
                    ad_2.Fill(ds_2_rel.Tables[0]);//заполняем 1-ю таблицу
                    ad_2 = new SqlDataAdapter("select * from " + SwjazBox2.Text, con_2);
                    ad_2.FillSchema(ds_2_rel.Tables[1], SchemaType.Source);
                    ad_2.Fill(ds_2_rel.Tables[1]);//заполняем 2-ю таблицу
                    DataColumn par = ds_2_rel.Tables[0].Columns[KBox1.Text];
                    DataColumn child = ds_2_rel.Tables[1].Columns[KBox2.Text];
                    //делаем связь через столбцы
                    DataRelation re_2 = new DataRelation("FK_" + SwjazBox1.Text + "_" + SwjazBox2.Text, par, child, true);
                    ds_2_rel.Relations.Add(re_2);//добавляем эту всязь в ds_2_rel
                    //dGV5.DataSource = ds_2_rel;
                    //dGV5.DataMember = ds_2_rel.Tables[0].ToString();
                    //-----------------
                    dGV5.DataSource = parent;
                    dGV4.DataSource = children;
                    parent.DataSource = ds_2_rel;
                    parent.DataMember = ds_2_rel.Tables[0].ToString();
                    children.DataSource = parent;
                    children.DataMember = re_2.ToString();    //ds_2_rel.Tables[1].ToString();
 
                    for (int i2 = 0; i2 < dGV5.ColumnCount; i2++) { dGV5.Columns[i2].Width = 65; }
                    //dGV4.DataSource = ds_2_rel;
                    //dGV4.DataMember = ds_2_rel.Tables[1].ToString();
                    for (int i2 = 0; i2 < dGV4.ColumnCount; i2++) { dGV4.Columns[i2].Width = 65; }
                }
                catch (Exception ex) { MessageBox.Show(ex.Message.ToString()); }
                con_2.Close();
            }
правда нужно создать дополнительно
C#
1
2
BindingSource parent = new BindingSource();
        BindingSource children = new BindingSource();
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.05.2010, 10:00
Помогаю со студенческими работами здесь

Работа с Windows Form
Всем привет. Ребята подскажите плиз, ест ли какая книга где рассказывается как работать в проектах Windows Form, я имею ввиду где будут все...

работа с windows form c#
Ув.Кодеры Помогите разобраться с задачами 1.в windows form нужно что б изображение в форме передвигалось по косой линии внутри формы ...

Работа с Windows Form
Здравствуйте. Подскажите, пожалуйста,... Я создаю приложение в Visual Studio C++ 2008 и столкнулся со следующей проблеммой: мое...

Работа с цветами Windows Form
Доброй ночи товарищиЮ достиг огромного прогресса в программировании спасибо за что форуму и фрилансу,у меня вот имеется программа, в...

Создать таблицы базы данных. Соединить их соответствующими связями. Заполнить таблицы записями (по 10 шт.)
Помогите пожалуйста, может образец какой-то есть у кого, на самообучение дали Access. И задачки... а я понять не могу. Вот задачка. ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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