Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/18: Рейтинг темы: голосов - 18, средняя оценка - 4.72
1 / 1 / 0
Регистрация: 27.04.2015
Сообщений: 49

Заполнение treeview из бд

10.11.2016, 07:33. Показов 3708. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
День добрый.
Есть бд в которой таблицы с полями devices (id, dev_name), folders (id, folder_name, parent_device), subfolders (id, subfolder_name, parent_folder).
Подскажите как сделать что бы в TreeView заполнились данные из бд?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.11.2016, 07:33
Ответы с готовыми решениями:

Заполнение и работа с TreeView
Доброго времени суток. Есть TV, которое заполняется из БД и умеет вид: 1. _1.1. 2. _2.1. __2.1.1. __2.1.2. _2.2.

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

Заполнение TreeView данными из БД
Помогите создать два уровня в TreeView. Первый уровень я создал... А вот второй не получается. вот код: ...

9
5975 / 4550 / 1095
Регистрация: 29.08.2013
Сообщений: 28,172
Записей в блоге: 3
10.11.2016, 10:21
запросом получить данные из бд
потом заполнить Treeview
0
1 / 1 / 0
Регистрация: 27.04.2015
Сообщений: 49
10.11.2016, 10:27  [ТС]
Цитата Сообщение от qwertehok Посмотреть сообщение
запросом получить данные из бд
Подскажи как выглядит запрос???
0
5975 / 4550 / 1095
Регистрация: 29.08.2013
Сообщений: 28,172
Записей в блоге: 3
10.11.2016, 10:36
SQL
1
SELECT * FROM [твоя таблица]
0
1 / 1 / 0
Регистрация: 27.04.2015
Сообщений: 49
10.11.2016, 10:46  [ТС]
Delphi
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
procedure TForm3.FormCreate(Sender: TObject);
var w:tsimplestring;
begin
for g:=1 to 10 do
  begin
    DataModule2.ADOQuery1.Active:=false;
    DataModule2.ADOQuery1.SQL.Clear;
     DataModule2.ADOQuery1.SQL.Add('select * from devices where id');
 
    DataModule2.ADOQuery1.Open;
    s:=DataModule2.ADOQuery1.Fields[0].Asinteger;
    rootnode:=TreeView1.Items.AddChild(nil, DataModule2.ADOQuery1.Fields[1].AsString);
 
    DataModule2.ADOQuery1.Active:=false;
    DataModule2.ADOQuery1.SQL.Clear;
    DataModule2.ADOQuery1.SQL.Add('select * from folders where parent_device');
        DataModule2.ADOQuery1.Open;
 
    with DataModule2.ADOQuery1 do
    while not eof do begin
    w:=tsimplestring.Create;
    w.text:=(IntToStr(s))+DataModule2.ADOQuery1.Fields[0].AsString;
    anode:=TreeView1.Items.AddChild(rootnode, DataModule2.ADOQuery1.Fields[2].AsString);
    anode.Data:=w;
    DataModule2.ADOQuery1.Next;
    end;
  end;
Использовал этот код, у меня отображается 10 записей одинаковых, а в них подпапки все цифрой 1( Где я ошибся???
0
5975 / 4550 / 1095
Регистрация: 29.08.2013
Сообщений: 28,172
Записей в блоге: 3
10.11.2016, 14:20
Цитата Сообщение от Makxak Посмотреть сообщение
Где я ошибся???
голову то надо включать

возьми ручку и бумажку и по шагам пройдись что делает твой код
0
1 / 1 / 0
Регистрация: 27.04.2015
Сообщений: 49
10.11.2016, 16:56  [ТС]
Цитата Сообщение от qwertehok Посмотреть сообщение
голову то надо включать
возьми ручку и бумажку и по шагам пройдись что делает твой код
Уважаемый, зная я свою ошибку исправил бы сам. Будте добры указать мне конкретно где этот код неверно написан. Заранее благодарю.
0
174 / 160 / 71
Регистрация: 22.02.2013
Сообщений: 1,769
Записей в блоге: 2
10.11.2016, 17:40
Makxak,

Delphi
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
var w:tsimplestring;
begin
 
    DataModule2.ADOQuery1.Active:=false;
    DataModule2.ADOQuery1.SQL.Clear;
     DataModule2.ADOQuery1.SQL.Add('select * from device');
 
    DataModule2.ADOQuery1.Open;
   while not (ADOQuery1.eof) do
begin
    s:=DataModule2.ADOQuery1.Fields[0].Asinteger;
    rootnode:=TreeView1.Items.AddChild(nil, DataModule2.ADOQuery1.Fields[1].AsString);
 
    DataModule2.ADOQuery2.Active:=false;
    DataModule2.ADOQuery2.SQL.Clear;
    DataModule2.ADOQuery2.SQL.Add('select * from folders where parent_device = ' +DataModule2.ADOQuery1.FieldByName('Id').asstring );
      DataModule2.ADOQuery2.Open;
 
    with DataModule2.ADOQuery2 do
    while not eof do begin
    w:=tsimplestring.Create;
    w.text:=(IntToStr(s))+DataModule2.ADOQuery2.Fields[0].AsString;
    anode:=TreeView1.Items.AddChild(rootnode, DataModule2.ADOQuery2.Fields[2].AsString);
    anode.Data:=w;
    DataModule2.ADOQuery2.Next;
    end;
ADOQuery1.Next;
end;
  end;
1
5975 / 4550 / 1095
Регистрация: 29.08.2013
Сообщений: 28,172
Записей в блоге: 3
10.11.2016, 19:49
Цитата Сообщение от Makxak Посмотреть сообщение
Уважаемый, зная я свою ошибку исправил бы сам
так узнайте
сядьте и по шагам отладьте СВОЙ код

Цитата Сообщение от Makxak Посмотреть сообщение
Будте добры указать мне конкретно где этот код неверно написан
у вас код то правильный, а вот логика хромает
0
1 / 1 / 0
Регистрация: 27.04.2015
Сообщений: 49
11.11.2016, 06:56  [ТС]
Цитата Сообщение от NotBeginner Посмотреть сообщение
var w:tsimplestring;
begin
DataModule2.ADOQuery1.Active:=false;
* * DataModule2.ADOQuery1.SQL.Clear;
* * *DataModule2.ADOQuery1.SQL.Add('select * from device');
DataModule2.ADOQuery1.Open;
* *while not (ADOQuery1.eof) do
begin
* * s:=DataModule2.ADOQuery1.Fields[0].Asinteger;
* * rootnode:=TreeView1.Items.AddChild(nil, DataModule2.ADOQuery1.Fields[1].AsString);
DataModule2.ADOQuery2.Active:=false;
* * DataModule2.ADOQuery2.SQL.Clear;
* * DataModule2.ADOQuery2.SQL.Add('select * from folders where parent_device = ' +DataModule2.ADOQuery1.FieldByName('Id') .asstring );
* * * DataModule2.ADOQuery2.Open;
with DataModule2.ADOQuery2 do
* * while not eof do begin
* * w:=tsimplestring.Create;
* * w.text:=(IntToStr(s))+DataModule2.ADOQue ry2.Fields[0].AsString;
* * anode:=TreeView1.Items.AddChild(rootnode , DataModule2.ADOQuery2.Fields[2].AsString);
* * anode.Data:=w;
* * DataModule2.ADOQuery2.Next;
* * end;
ADOQuery1.Next;
end;
* end;
Отлично, чутка исправил и древо построилось.
Вопрос как добавить 3-ий уровень???
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.11.2016, 06:56
Помогаю со студенческими работами здесь

Заполнение treeView
Добрый день. Помогите с заполнением древовидного списка. Делаю запрос к БД, содержащий три поля: -ид элемента -ид родительского...

Заполнение TreeView
Есть на форме TreeView, и мне нужно заполнить его всем тем что есть в Инспекторе обьектов компонента Label. Заполнять вручную долго 30...

заполнение treeView
Уважаемые программисты, владеющие языком C#! Вот мой ступор: Задача следующая: пусть имеется некоторая таблица. Нужно данные перенести в...

Заполнение TreeView
Доброго времени суток уважаемые форумчане у меня есть задача с которой сам справиться не могу и прошу помощи у Вас. У меня есть TreeView...

Заполнение treeView
Здравствуйте! Скажите пожалуйста, Как заполнить узлов treeView из бд и получить id?


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru