Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
 Аватар для sg-ua
0 / 0 / 1
Регистрация: 17.09.2012
Сообщений: 113

Выполнить запрос к БД при нажатии на элемент в ListView и заполнить данными другой ListView

09.05.2015, 12:15. Показов 1710. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите пожалуйста как сделать в RadStudio, что бы при нажатии на одну строку выполнялся запрос в БД, и результат записывался в чистый ListView?
C++
1
2
3
4
5
6
7
8
9
10
11
12
void __fastcall TTabbedwithNavigationForm::OnItemClick(TObject *Sender)
{
    char a = 'Пицца';
    while(!ADOQuery1->Eof){
    ADOQuery1->Active= false;
    ADOQuery1->SQL->Text="select name_dish from блюдо where a = :a";
    ADOQuery1->Active = true;
    ListView1->Items->BeginUpdate();
    ListView1->Items->Add()->Text=ADOQuery1->FieldByName("name_dish")->AsString;
    ListView1->Items->EndUpdate();
    }
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.05.2015, 12:15
Ответы с готовыми решениями:

Как перетащить элемент из ListView в другой ListView?
У меня есть форма на ней два ListView хочу из одного ListView в другой ListView перетащить объект. Как это сделать? Подскажите плиз.:wall:

Открыть картинку при нажатии на элемент ListView
Добрый вечер. Нужна помощь вот в чем. В общем есть ListView. Допустим мне нужно чтобы при нажатии на какой то элемент списка у меня...

Открыть активити при нажатии на элемент Listview
Здравствуйте, в андроид-программирование не давно, подскажите пожалуйста как, чтобы при нажатии на один элемент списка listview открывалась...

10
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
09.05.2015, 14:56
Цитата Сообщение от sg-ua Посмотреть сообщение
при нажатии на одну строку
На какую именно строку?
0
 Аватар для sg-ua
0 / 0 / 1
Регистрация: 17.09.2012
Сообщений: 113
09.05.2015, 15:12  [ТС]
Подправил код, при нажатии список очищается , но потом выбивает ошибку
неправильно определен объект Parameter. Предоставлено не совместимы или неполные сведения
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void __fastcall TTabbedwithNavigationForm::ListView1Change(TObject *Sender)
{
    char a = 'Пицца';
    ListView1->ClearItems();
    ADOQuery1->Active= false;
    ADOQuery1->SQL->Text="select name_dish from блюдо where a = :a";
    ADOQuery1->Active = true;
    while(!ADOQuery1->Eof){
 
    ListView1->Items->Add()->Text=ADOQuery1->FieldByName("name_dish")->AsString;
    ADOQuery1->Next();
    }
 
    }
на любую строчку
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33412 / 21522 / 8236
Регистрация: 22.10.2011
Сообщений: 36,922
Записей в блоге: 12
09.05.2015, 15:18
C++
1
2
3
4
ADOQuery1->SQL->Text="select name_dish from блюдо where a = :a";
ADOQuery1->Parameters->ParamByName("a")->Value="Пицца";
ADOQuery1->Active = true;
// ...
1
 Аватар для sg-ua
0 / 0 / 1
Регистрация: 17.09.2012
Сообщений: 113
09.05.2015, 15:31  [ТС]
Вот такая ошибка! и еще хотел параллельно спросить, у меня значения "Пицца" будет изменяться, то есть у каждой строчки будет свое значение, которое приписано :
C++
1
ListView1->Items->Text
как сделать сразу так что бы, нажимаешь на строчку и оно брало свое значения заносило в запрос?
Миниатюры
Выполнить запрос к БД при нажатии на элемент в ListView и заполнить данными другой ListView  
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33412 / 21522 / 8236
Регистрация: 22.10.2011
Сообщений: 36,922
Записей в блоге: 12
09.05.2015, 15:47
sg-ua, ну так подставь в запрос после WHERE название поля, которое должно сравниваться с твоей "пиццей", откуда я знаю, как у тебя в базе поля называются?

Добавлено через 2 минуты
Цитата Сообщение от sg-ua Посмотреть сообщение
что бы, нажимаешь на строчку и оно брало свое значения
На строчку ГДЕ? В каком компоненте?
0
 Аватар для sg-ua
0 / 0 / 1
Регистрация: 17.09.2012
Сообщений: 113
09.05.2015, 19:49  [ТС]
Компонент TListView...там я чуть-чуть не верно объяснил, у меня есть две таблицы в БД: ТИП БЛЮДА(ID_ТИП,NAME) и БЛЮДО(ID,NAME, ID_ТИП). Пользователь в программе нажимает кнопку, создается список TListView с таб. ТИП БЛЮДА поле NAME. Пользователь может нажать на любою строчку(Пицца, Десерт), программа должна взять соответствующие значение с поле ID_ТИП, и сделать запрос по "WHERE соответствующие значение с поле ID_ТИП" с таблицы БЛЮДО и занести в список TListView

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
    void __fastcall TTabbedwithNavigationForm::Button1Click(TObject *Sender)
{
    ADOQuery1->Active= false;
    ADOQuery1->SQL->Text="select * from type ";
    ADOQuery1->Active = true;
  while(!ADOQuery1->Eof){
    ListView1->Items->Add()->Text=ADOQuery1->FieldByName("name_type")->AsString;
    ADOQuery1->Next();
    }
    
}
//---------------------------------------------------------------------------
 
 
void __fastcall TTabbedwithNavigationForm::ListView1OnClick(TObject *Sender)
{
 
    ListView1->ClearItems();
    ADOQuery1->Active= false;
    ADOQuery1->SQL->Text="select name_dish from Блюдо where type = :a";
    ADOQuery1->Parameters->ParamByName("a")->Value="1";
    ADOQuery1->Active = true;
    while(!ADOQuery1->Eof){
 
    ListView1->Items->Add()->Text=ADOQuery1->FieldByName("name_dish")->AsString;
    ADOQuery1->Next();
    }
 
    }
Добавлено через 3 часа 40 минут
просидел уже несколько часов, так не могу понять как узнать какой Item пользователь нажал
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33412 / 21522 / 8236
Регистрация: 22.10.2011
Сообщений: 36,922
Записей в блоге: 12
09.05.2015, 19:58
Для этого достаточно обработать событие OnClick твоего ListView (и посмотреть ListView1->Selected->Caption), у OnChange совсем другой обработчик, там должно быть 3 параметра, а не один...
0
 Аватар для sg-ua
0 / 0 / 1
Регистрация: 17.09.2012
Сообщений: 113
09.05.2015, 20:20  [ТС]
Вот эту часть я что-то не понял
там должно быть 3 параметра
Сделал так(как Caption, нет такого параметра)
C++
1
    ShowMessage(ListView1->Selected->Text);
Программа запускается только вылетает такая ошибка?
Миниатюры
Выполнить запрос к БД при нажатии на элемент в ListView и заполнить данными другой ListView  
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33412 / 21522 / 8236
Регистрация: 22.10.2011
Сообщений: 36,922
Записей в блоге: 12
09.05.2015, 20:22
Цитата Сообщение от sg-ua Посмотреть сообщение
как Caption, нет такого параметра
Что значит "нет"? Приложение у тебя какое? VCL? Должен быть Caption у TListItem...
0
 Аватар для sg-ua
0 / 0 / 1
Регистрация: 17.09.2012
Сообщений: 113
09.05.2015, 21:03  [ТС]
У меня Multi-Device

Добавлено через 6 минут
Ошибка была в тому что я чистил список перед этим..volvo спасибо тебе. но еще попрошу тебя сказать что ты имел ввиду
там должно быть 3 параметра
Добавлено через 29 минут
извините, но можете еще подсказать как заполнить одновременно два поля?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void __fastcall TTabbedwithNavigationForm::ListView1OnClick(TObject *Sender)
{
    ADOQuery1->Active= false;
    ADOQuery1->SQL->Text="select name_dish, structure from Страви, type where type.id_type=Страви.type and type.name_type= :dish";
    ADOQuery1->Parameters->ParamByName("dish")->Value=ListView1->Selected->Text;
    ListView1->ClearItems();
    ADOQuery1->Active = true;
    
while(!ADOQuery1->Eof){
    ListView1->Items->Add()->Text=ADOQuery1->FieldByName("name_dish")->AsString; //?????
    ListView1->Items->Add()->Detail=ADOQuery1->FieldByName("structure")->AsString; //?????
    ADOQuery1->Next();
    }
 
    }
//-----
Проблема в тому что выводит каждый раз пустую строку
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.05.2015, 21:03
Помогаю со студенческими работами здесь

При нажатии на элемент в ListView надо выделить всю строку
Вот код,( после выделения мне нужно будет удалить выделенную строку) station_list_view = CreateWindow(WC_LISTVIEW,...

При нажатии на элемент ListView вывести новое Activity с информацией об этом элементе
Здравствуйте! Помогите пожалуйста! В общем есть список ListView с названиями кафе и ресторанов, надо сделать так чтобы при нажатии на...

Как заполнить ListView данными из Класса
Здравствуйте. Срочно нужна помощь. Имею программу, которую берет объекты класса из WebApi. После чего они сохраняются в переменную типа...

При нажатии на кнопку создать запрос на другой странице с выбранными данными и датой
Здравствуйте помогите очень надо! нужно при нажатии на кнопку создать запрос на другой странице с выбранными данными и датой!

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


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru