Форум программистов, компьютерный форум, киберфорум
C#: WPF, UWP и Silverlight
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
1 / 1 / 1
Регистрация: 04.11.2015
Сообщений: 62

Из sql в treeview

01.02.2020, 14:42. Показов 2923. Ответов 7

Студворк — интернет-сервис помощи студентам
Есть следующая таблица в MS SQL. Задание - вывести эту таблицу в treeview 2 способами: с помощью sqlDataAdapter; с помощью Entity Framework.
Миниатюры
Из sql в treeview  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.02.2020, 14:42
Ответы с готовыми решениями:

TreeView и sql
Всем привет. Есть treeView. Есть таблица состоящая из столбцов idmenu,name, read_full В idmenu это идентификатор меню, name имя меню и...

TreeView & SQL
Доброго времени суток всем! Возможно задача вполне тривиальна, но я никак не могу с ней справится. Необходимо заполнить TreeView...

Заполнение TreeView из MS SQL
Добрый день, возникла такая задача: Необходимо заполнить treeview из SQL (пример таблицы прикладываю) Суть заключается в том, что...

7
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16140 / 11264 / 2888
Регистрация: 21.04.2018
Сообщений: 33,110
Записей в блоге: 2
01.02.2020, 15:09
Цитата Сообщение от pashocheck Посмотреть сообщение
Есть следующая таблица в MS SQL. Задание - вывести эту таблицу в treeview 2 способами: с помощью sqlDataAdapter; с помощью Entity Framework.
И что вы сами пока смогли сделать?
0
1 / 1 / 1
Регистрация: 04.11.2015
Сообщений: 62
01.02.2020, 15:18  [ТС]
Пока только понял, что можно записать все данные в datagridview например с следующим запросом
SQL
1
2
3
4
5
6
7
8
9
SELECT t2.Name AS Name2, dbo.GROUP_CONCAT(t1.Name) AS Name3
FROM
  [Unicorn].[dbo].[Test] t1 JOIN [Unicorn].[dbo].[Test] t2
    ON t1.ParentID = t2.id
    JOIN [Unicorn].[dbo].[Test] t3
    ON t2.ParentID = t3.ID
WHERE
  t3.ParentID IS NULL
  GROUP BY t3.Name, t2.Name
А затем из datagrid вывести в treeview
Вот только в wpf я впервые, пытаюсь разобраться в вашем коде с предыдущей темы, где что-то похоже
0
Модератор
Эксперт .NET
 Аватар для Yury Komar
4358 / 3428 / 512
Регистрация: 27.01.2014
Сообщений: 6,258
01.02.2020, 16:04
Цитата Сообщение от pashocheck Посмотреть сообщение
можно записать все данные в datagridview
а надо так
Цитата Сообщение от pashocheck Посмотреть сообщение
вывести эту таблицу в treeview
Добавлено через 44 секунды
pashocheck, а почему WPF?
0
1 / 1 / 1
Регистрация: 04.11.2015
Сообщений: 62
01.02.2020, 16:07  [ТС]
Цитата Сообщение от Yury Komar Посмотреть сообщение
а почему WPF?
Потому что в итоге буду писать именно wpf приложения, но если у вас есть решение для windows forms, то я бы посмотрел
0
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16140 / 11264 / 2888
Регистрация: 21.04.2018
Сообщений: 33,110
Записей в блоге: 2
01.02.2020, 16:32
Цитата Сообщение от pashocheck Посмотреть сообщение
Вот только в wpf я впервые, пытаюсь разобраться в вашем коде с предыдущей темы, где что-то похоже
Я не делаю приложений в которых данные и их представление смешано в одну кучу.
Особенно когда данные надо получать из БД.
Такое возможно, но создаёт кучу побочных проблем.

В вашей задаче вам надо создать тип для передачи данных.
Пока задачи редактирования данных не стоит, поэтому можно использовать всюду неизменяемый тип DTO
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
    public class IdNameDTO
    {
        public int Id { get; }
        public string Name { get; }
        public int IdParent { get; }
        public IdNameDTO(int id, string name, int idParent = 0)
        {
            Id = id;
            Name = name;
            IdParent = idParent;
        }
 
        public class IdEqualityComparer : IEqualityComparer<IdNameDTO>
        {
            public bool Equals(IdNameDTO x, IdNameDTO y)
                => x.Id.Equals(y.Id);
 
            public int GetHashCode(IdNameDTO obj)
                => obj.GetHashCode();
        }
    }
Потом вам нужен интерфейс для "общения ViewModel и Model"
C#
1
2
3
4
5
6
public interface INameModel
{
   string Source {get;}
   void Load(string source);
   HashSet<IdNameDTO> GetIdNames();
}
ViewModel будет работать с этим интерфейсом. Каким образом Model получает данные (SqlDataAdapter или EF, или даже XML) ей безразлично.

Сделайте сначала ту Модель которую вам проще.
Начинается она с реализации INameModel.
Допустим для SqlDataAdapter она начинается так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public class ModelSDA : INameModel
{
   public string Source {get; private set;}
   public void Load(string source) => Source = source;
   public HashSet<IdNameDTO> GetIdNames()
   {
         HashSet<IdNameDTO> names 
             = new HashSet<IdNameDTO>(new IdNameDTO.IdEqualityComparer());
 
         /// Здесь получение данных с помощью SDA,
         /// их преобразование в тип IdNameDTO 
         /// и запись в множество  names.
        /// После чего это множество возвращается методом
 
        return names;
    }
}
Когда сделаете это - покажите что получилась. И продолжим дальше.
1
1 / 1 / 1
Регистрация: 04.11.2015
Сообщений: 62
01.02.2020, 18:55  [ТС]
Цитата Сообщение от Элд Хасп Посмотреть сообщение
покажите что получилась
Что-то вообще тупняк у меня

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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Data.SqlClient;
using System.Data;
 
namespace WpfApplication4
{
    /// <summary>
    /// Логика взаимодействия для MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }
    }
 
    public class IdNameDTO
    {
        private DataSet d;
 
        public int Id { get; }
        public string Name { get; }
        public int IdParent { get; }
        public IdNameDTO(int id, string name, int idParent = 0)
        {
            Id = id;
            Name = name;
            IdParent = idParent;
        }
 
        public IdNameDTO(DataSet d)
        {
            this.d = d;
        }
 
        public class IdEqualityComparer : IEqualityComparer<IdNameDTO>
        {
            public bool Equals(IdNameDTO x, IdNameDTO y)
                => x.Id.Equals(y.Id);
 
            public int GetHashCode(IdNameDTO obj)
                => obj.GetHashCode();
        }
 
        public static implicit operator HashSet<object>(IdNameDTO v)
        {
            throw new NotImplementedException();
        }
    }
 
    public interface INameModel
    {
        string Source { get; }
        void Load(string source);
        HashSet<IdNameDTO> GetIdNames();
    }
    
 
    public class ModelSDA : INameModel
    {
        public string Source { get; private set; }
        public void Load(string source) => Source = source;
        public HashSet<IdNameDTO> GetIdNames()
        {
            HashSet<IdNameDTO> names
                = new HashSet<IdNameDTO>(new IdNameDTO.IdEqualityComparer());
 
            /// Здесь получение данных с помощью SDA,
            /// их преобразование в тип IdNameDTO 
            /// и запись в множество  names.
            /// После чего это множество возвращается методом
            string connectionString = @"Data Source=.\SQLEXPRESS;Initial Catalog=Unicorn;Integrated Security=True";
            string sql = "SELECT * FROM Test";
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();
                SqlDataAdapter adapter = new SqlDataAdapter(sql, connection);
                DataSet d = new DataSet();
                adapter.Fill(d);
                IdNameDTO dt = new IdNameDTO(d);
               // DataTable dt = new DataTable();
 
                names = dt;
            }
 
            return names;
        }
    }
}
в формах попытался написать, но почему-то записывает только последнее значение родителя

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
78
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.Sql;
using System.Data.SqlClient;
 
namespace WindowsFormsApplication3
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
 
            string connectionString = @"Data Source=.\SQLEXPRESS;Initial Catalog=Unicorn;Integrated Security=True";
            string sql = "SELECT Name as Parent FROM Test WHERE ParentID IS NULL";
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();
                SqlDataAdapter adapter = new SqlDataAdapter(sql, connection);
                DataSet ds = new DataSet();
               // DataTable dt = new DataTable();
                adapter.Fill(ds);
                // adapter.Fill(dt);
 
                dataGridView1.DataSource = ds.Tables[0];
            }
 
            string connectionString1 = @"Data Source=.\SQLEXPRESS;Initial Catalog=Unicorn;Integrated Security=True";
            string sql1 = "SELECT t2.Name as Childs FROM [Unicorn].[dbo].[Test] t1 JOIN[Unicorn].[dbo].[Test] t2 ON t1.ParentID = t2.id JOIN[Unicorn].[dbo].[Test] t3 ON t2.ParentID = t3.ID WHERE t3.ParentID IS NULL GROUP BY t3.Name, t2.Name";
            using (SqlConnection connection1 = new SqlConnection(connectionString1))
            {
                connection1.Open();
                SqlDataAdapter adapter1 = new SqlDataAdapter(sql1, connection1);
                DataSet ds1 = new DataSet();
                adapter1.Fill(ds1);
 
                dataGridView2.DataSource = ds1.Tables[0];
            }
 
            string connectionString2 = @"Data Source=.\SQLEXPRESS;Initial Catalog=Unicorn;Integrated Security=True";
            string sql2 = "SELECT dbo.GROUP_CONCAT(t1.Name) AS DochCompanyes FROM [Unicorn].[dbo].[Test] t1 JOIN[Unicorn].[dbo].[Test] t2 ON t1.ParentID = t2.id JOIN[Unicorn].[dbo].[Test] t3 ON t2.ParentID = t3.ID WHERE t3.ParentID IS NULL GROUP BY t3.Name, t2.Name";
            using (SqlConnection connection2 = new SqlConnection(connectionString2))
            {
                connection2.Open();
                SqlDataAdapter adapter2 = new SqlDataAdapter(sql2, connection2);
                DataSet ds2 = new DataSet();
                adapter2.Fill(ds2);
 
                dataGridView3.DataSource = ds2.Tables[0];
            }
 
            TreeNode rootNode = new TreeNode();
            
            for (int i = 0; i <= dataGridView1.Rows.Count-2; i++)
            {
                string a = dataGridView1[0, i].Value.ToString();
                rootNode.Name = a;
                rootNode.Text = a;
                treeView1.Nodes.Add(rootNode);
            }
 
 
           // treeView1.Nodes.Add("Мотоциклы");
 
 
            TreeNode autoNode = treeView1.Nodes[0];
            autoNode.Nodes.Add("Child", dataGridView2[0, 0].Value.ToString());
            treeView1.Nodes[0].Nodes["Child"].Nodes.Add("DochComp", dataGridView3[0, 0].Value.ToString());
        }
    }
}
0
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16140 / 11264 / 2888
Регистрация: 21.04.2018
Сообщений: 33,110
Записей в блоге: 2
01.02.2020, 19:16
Лучший ответ Сообщение было отмечено pashocheck как решение

Решение

Цитата Сообщение от pashocheck Посмотреть сообщение
Что-то вообще тупняк у меня
Вынесите все типы в отдельные файла.
Так даже смотреть код неудобно, не то, что писать его.

Ни какого DatSet в DTO быть не должно!
В DTO кроме свойств нет ни какой логику. Максимум только логика сравнения.

Добавлено через 1 минуту
Я вам дал полный код DTO типа.
Ничего больше в нём не нужно.
Просто скопируйте его и всё!

Добавлено через 13 минут
В отдельном файле!
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
    public class ModelSDA : INameModel
    {
        public string Source { get; private set; }
        public void Load(string source) => Source = source;
        public HashSet<IdNameDTO> GetIdNames()
        {
            HashSet<IdNameDTO> names
                = new HashSet<IdNameDTO>(new IdNameDTO.IdEqualityComparer());
 
            /// Здесь получение данных с помощью SDA,
            /// их преобразование в тип IdNameDTO 
            /// и запись в множество  names.
            /// После чего это множество возвращается методом
   //         string connectionString = @"Data Source=.\SQLEXPRESS;Initial Catalog=Unicorn;Integrated Security=True";
            string sql = "SELECT * FROM Test";
            DataSet d = new DataSet();   
 
            using (SqlConnection connection = new SqlConnection(Source))
            {
                connection.Open();
                SqlDataAdapter adapter = new SqlDataAdapter(sql, connection);
 
                adapter.Fill(d);
            }
 
 
/// Создание по каждой строке таблицы DTO типа
            foreach(var row in d)
                  names.Add( new IdNameDTO
                  (
                      (int) row["Id"],     /// Правильные названия ваших полей не знаю
                      (string) row["Name"], /// сами исправите на свои
                      (int) row["IdParent"]
                  ));
 
            return names;
        }
    }
Создайте в консоле экземпляр Model, получите данные из него и проверьте на сколько они соответствуют вашим в базе
C#
1
2
3
4
ModelSDA model = new ModelSDA();
model.Load(@"Data Source=.\SQLEXPRESS;Initial Catalog=Unicorn;Integrated Security=True");
foreach(IdNameDTO dto in model.GetIdNames())
  Console.WriteLine($"{dto.Id} {dto.Name} {dto.IdParent}");
Добавлено через 2 минуты
Ещё одно замечание.
Поле ParentID не должно допускать null.
Для элементов верхнего уровня устанавливайте ParentID неположительным (обычно = 0).
Так будет удобнее в использование. Иначе придётся по всему коду вставлять проверки на null.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.02.2020, 19:16
Помогаю со студенческими работами здесь

Заполнение treeview из sql
Ребят помогите пожалуйста облазил весь интернет , не как не могу понять!Есть у меня простенькая база данный , состоящая из одной таблицы...

Заполнение TreeView из БД SQL
Здравствуйте, помогите пожалуйста чайнику:) В универе поставили задачу: заполнить компонент TreeView данными из базы данных. У меня...

Отображение данных из MS SQL в TreeView
Здравствуйте! Прошу помочь. Есть БД из нескольких таблиц. Надо их отобразить в дереве TreeView. Я новичок в программировании, поэтому...

Отображение sql дерева в TreeView
Добрый день! Еще недавно я создал тему в разделе ASP.NET MVC в которой я спрашивал как возможно отобразить дерево sql на страничке. Судя по...

Считать SQL-выборку в TreeView
Здравствуйте. При написании работы возникла следующая проблема - мне необходимо считать выборку из трех таблиц в элемент TreeView. Таблицы...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru