|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|||||||||||
Заполнить treeview данными из трех связанных один-к-одному таблиц23.07.2021, 08:50. Показов 964. Ответов 16
Метки нет (Все метки)
Перенесено из темы Заполнить treeview из таблицы базы данных хранящей дерево
Добрый день, помогите разобраться, пытаюсь заполнить treeview данными из трех связанных один-к-одному таблиц, скрин таблиц прилагаю. мой код:
Буду очень признателен за помощь.
0
|
|||||||||||
| 23.07.2021, 08:50 | |
|
Ответы с готовыми решениями:
16
Выборка элементов из таблиц, связанных связью "один к одному" Заполнение данными на SQL двух связанных таблиц Запрос на выборку из трёх связанных таблиц |
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
|
| 24.07.2021, 00:30 | |
|
aksident, Ваш код имеет ряд существенных минусов
1. Вы "закладываетесь" на 3 уровня, соответственно три очень похожих таблицы. А что, если потребуется еще один уровень, а то и два ? 2. Ваш код жестко привязан к колонкам таблиц, что неумолимо приведет к полной его переделке если что-то поменяется в консерватории, т.е. в БД 3. Циклы. Та же история с уровнем вложенности. Все очень "зашито", а это плохо. Все три проблемы решаются с помощью одной, "деревянной" таблицы и рекурсивной выборкой с обходом "деток" при разузловании (как было указано выше). Добавлено через 7 минут Опыт показывает, что при больших "деревьях" незачем все его содержимое (вплоть до листьев) тащить на Клиент, юзер просмотрит в лучшем случае процентов 10. Остальные останутся невостребованными. Поэтому есть способ получше - при первом входе на страницу показываются только узлы 1-го уровня, например континенты. Если надо посмотреть "Европу", то юзер раскрывает узел с помощью пиктограммки рядом с названием нужного континента (Европы) - при этом асинхронно с сервера извлекаются только страны Европы и раскрываются под Европой. Нужно посмотреть, к примеру Россию, кликаем на иконке рядом с нею и получаем города. И т.д. Любой узел можно свернуть (клик на развернутой иконке), а потом опять развернуть. При этом второй раз выборки по той же Европе не будет. При таком алгоритме рекурсия не нужна, нет лишней загрузки SQL-сервера, сети и непосредственно Клиента. В то же время юзер быстро ориентируется в "дереве" и легко находит то, что нужно
0
|
|
|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|
| 25.07.2021, 10:52 [ТС] | |
|
Спасибо за ответ, а можете скинуть пример кода для подобного решения? Схему связей
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
|||||||||||
| 25.07.2021, 13:05 | |||||||||||
|
aksident, У меня все примеры в MVC + MS SQL Server +EF
Добавлено через 5 минут Деревянная таблица: Модель (с профилями пользователей):
0
|
|||||||||||
|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|
| 25.07.2021, 15:54 [ТС] | |
|
Профили пользователя это данные вашей таблицы?
Добавлено через 2 часа 38 минут Хорошо, положим таблицу я создал, что дальше? я только начинаю разбираться, потому задаю, возможно, глупые вопросы.
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
|||
| 25.07.2021, 17:04 | |||
|
Т.е. когда юзер авторизируется, то он исходно получает таблицу животных в своем городе.
0
|
|||
|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|
| 25.07.2021, 17:11 [ТС] | |
|
У меня один пользователь, это я, мне такое городить незачем
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
||
| 25.07.2021, 18:45 | ||
![]() Вы задали вопрос и получили ответ. К "деревянной" таблице юзеры относятся косвенно - просто ссылаются на нее. "Дереву" от этого ни жарко, ни холодно
0
|
||
|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|
| 25.07.2021, 19:04 [ТС] | |
|
по моему мы не в ту степь понеслись, у меня есть 3 таблицы связанные между собой в порядке подчиненности, мне просто нужно заполнить дерево данными из этих таблиц, да, данных там будет многовато, вот мне нужен совет как это реализовать. Доступ к этому дереву общий для всех пользователей, привязка к ним не нужна.
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
||||||||||||
| 25.07.2021, 23:09 | ||||||||||||
|
Добавлено через 53 минуты Выборка всего дерева из 3 связанных таблиц Таблицы:
1
|
||||||||||||
|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|
| 26.07.2021, 09:17 [ТС] | |
|
Спасибо большое за потраченное время
Добавлено через 53 минуты А не подскажете как это связать с кодом C# конкретного экземпляра treeview?
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
|
| 26.07.2021, 12:46 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|
| 26.07.2021, 12:53 [ТС] | |
|
элемент treeview visul studio C#
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
|
| 26.07.2021, 13:40 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|
| 26.07.2021, 14:04 [ТС] | |
|
нет, Windows Form
Добавлено через 19 минут Задал вопрос здесь потому что впервые на этом форуме и не заметил в какой конференции пишу, но удалить запись здесь нельзя, создал тему в соответствующей ветке но там тишина..
0
|
|
|
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
|
|
| 26.07.2021, 15:56 | |
|
aksident, Я так понял, что Вы хотите, чтобы Вам написали готовый код загрузки данных в TreeView из иерархически организованных 3 таблиц базы данных ? При этом сами думать не желаете категорически
![]() Просто подумать: указанным выше запросом получаете набор данных (тем же ридером к примеру, про ОРМ ведь Вы не слышали), он уже отсортирован как нужно, и просто пробегаете по нему (while (reader.Read()) и, сравнивая поля-ключи иерархии, добавляете новый узел либо в текущий как дочку, либо создаете новый дочерний и добавляете в него тоже как дочку. Добавлено через 5 минут Набрал в гугле c# Загрузка TreeView из БД и первые же 3 ссылки дали практически исчерпывающий ответ, как с рекурсией, так и по вышеприведенному способу с фиксированным количеством уровней с отдельными таблицами по уровням.
1
|
|
|
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
|
|
| 26.07.2021, 16:09 [ТС] | |
|
Да, спасибо, я уже почти разобрался.
0
|
|
| 26.07.2021, 16:09 | |
|
Помогаю со студенческими работами здесь
17
Вывод данных из трех связанных таблиц Вывод данных из трёх связанных таблиц
Сформировать запрос на выборку из трёх связанных таблиц Удаление данных из трёх связанных таблиц (Access) Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|