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

Вывод двух связанных таблиц данных в один Datagridview

08.10.2011, 21:58. Показов 5263. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Если можете подскажите, очень надо
Есть в БД SQL связанные таблицы:
1. Services_direction
Столбцы:
id_service_direction
Code_direction
Name_direction

2. Services
Столбцы:
id_service
Code_service
Name_service
id_service_direction
id_direction
Нужно на Windows форме в datagride вывести таблицу Services_direction и связанную с ней Services, так что бы у каждой строки Services_direction появился знак + , который означает, что у данной записи есть дочерняя запись.
Вроде всё верно, а плюсов нет, просто отображается таблица Services_direction.

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
SqlConnection sqlconn = new SqlConnection("Server=7EMOL;" +
                                                    "database=HelpAsistent;" +
                                                     "Integrated Security=True");
SqlCommand sqlcom = new SqlCommand();
sqlcom.Connection = sqlconn;
string commandText = "SELECT [id_service_direction], [Code_direction], [Name_direction] FROM [Services_direction]";
sqlcom.CommandText = commandText;
SqlDataAdapter DA = new SqlDataAdapter();
DA.SelectCommand = sqlcom;
sqlconn.Open();
DataSet ds = new DataSet();
DA.TableMappings.Add("Table", "Services_direction");
DA.Fill(ds);
SqlCommand sqlcom2 = new SqlCommand();
sqlcom2.Connection = sqlconn;
string commandText2 = "SELECT [id_service_direction], [id_service], [Code_service], [Name_service], [id_department] FROM [Services]";
sqlcom2.CommandText = commandText2;
SqlDataAdapter DA2 = new SqlDataAdapter();
DA2.SelectCommand = sqlcom2;
DA2.TableMappings.Add("Table", "Services");
DA2.Fill(ds);
 
DataColumn dcIDServicesDirection = ds.Tables["Services_direction"].Columns["id_service_direction"];
DataColumn dcInfoIDServicesDirection = ds.Tables["Services"].Columns["id_service_direction"];
DataRelation DR = new DataRelation("Dop_info", dcIDServicesDirection, dcInfoIDServicesDirection);
ds.Relations.Add(DR);
DataViewManager DM = ds.DefaultViewManager;
dataGridView1.DataSource = DM;
dataGridView1.DataMember = "Services_direction";
dataGridView1.Columns[0].HeaderText = "Ид_направления";
dataGridView1.Columns[1].HeaderText = "Код_направления";
dataGridView1.Columns[2].HeaderText = "Наименование_направления";
dataGridView1.Columns[2].Width = 450;
sqlconn.Close();
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.10.2011, 21:58
Ответы с готовыми решениями:

Вывод двух связанных таблиц данных в один элемент DataGridView
Добрый день нашел интересную ссылку про вывод связанных таблиц http://sernam.ru/book_cbd.php?id=43 База данных своя, не как в этом...

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

Вывод двух связанных таблиц в datagridview
Добрый день! нашел интересную ссылку про вывод связанных таблиц http://sernam.ru/book_cbd.php?id=43 using System; using...

1
0 / 0 / 2
Регистрация: 29.07.2011
Сообщений: 9
11.10.2011, 21:47  [ТС]
В один Datagridview через плюсы так и не получилось.
Сделала два Datagridview, в первом отображается главная таблица, а во втором - поля из дочерней таблицы, соответствующие id выбранному в главной таблице.
Вот код, кому нужен:

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
SqlConnection sqlconn = new SqlConnection("Server=7EMOL;" +
                                                    "database=HelpAsistent;" +
                                                     "Integrated Security=True");
            SqlCommand sqlcom = new SqlCommand();
            sqlcom.Connection = sqlconn;
            string commandText = "SELECT [id_service_direction], [Code_direction], [Name_direction] FROM [Services_direction]";
            sqlcom.CommandText = commandText;
            SqlDataAdapter DA = new SqlDataAdapter();
            DA.SelectCommand = sqlcom;
            sqlconn.Open();
 
            DataSet ds = new DataSet();
            DA.TableMappings.Add("Table", "Services_direction");
            DA.Fill(ds);
 
            SqlCommand sqlcom2 = new SqlCommand();
            sqlcom2.Connection = sqlconn;
            string commandText2 = "SELECT [id_service_direction], [id_service], [Code_service], [Name_service] FROM [Services]";
            sqlcom2.CommandText = commandText2;
            SqlDataAdapter DA2 = new SqlDataAdapter();
            DA2.SelectCommand = sqlcom2;
            DA2.TableMappings.Add("Table", "Services");
            DA2.Fill(ds);
 
            DataColumn dcIDServicesDirection = ds.Tables["Services_direction"].Columns["id_service_direction"];
            DataColumn dcInfoIDServicesDirection = ds.Tables["Services"].Columns["id_service_direction"];
            DataRelation DR = new DataRelation("Dop_info", dcIDServicesDirection, dcInfoIDServicesDirection);
            ds.Relations.Add(DR);
            DataViewManager DM = ds.DefaultViewManager;
            dataGridView1.DataSource = DM;
            dataGridView1.DataMember = "Services_direction";
          
            BindingSource bs1 = new BindingSource();
            bs1.DataSource = ds;
            bs1.DataMember = "Services_direction";
            BindingSource bs2 = new BindingSource();
            bs2.DataSource = bs1;
            bs2.DataMember = "Dop_info";
 
            dataGridView1.DataSource = bs1;
            dataGridView2.DataSource = bs2;
sqlconn.Close();
Теперь проблема с сохранением изменений в таблицах!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.10.2011, 21:47
Помогаю со студенческими работами здесь

Представление в DataGridView данных из двух связанных таблиц
Здравствуйте. Есть DataSet, в нем две связанных таблицы, например таблица Order, в которой есть внешний ключ ClientID и, соответственно,...

Вывод данных из двух таблиц в DataGridView
Привет Есть база, в ней 3 таблицы. В 1 таблице хранятся ФИО и ID. Во 2 таблице ID и операция, т.е. связь по полю ID. Делаю запрос (в...

Вывод в DataGridView данных из связанных таблиц
Доброго времени суток! В базе Access есть две таблицы Первая таблица с заголовками: ID , Название Товара. Вторая таблица с...

Вывод данных из двух таблиц БД в одну dataGridView
В БД две таблицы Reisi и Goroda. Таблицы связаны по полю IDtown. Пытаюсь вывести из таблицы Reisi все поля кроме IDtown, вместо...

Вывод связанных таблиц в DataGridView
Здравствуйте. Имеются три таблицы: Books (со столбцами ID, Name, Author, Genre), Authors (со столбцами ID, Name, Surname), Genres (со...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru