Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.07.08;
Скачать: CL | DM;

Вниз

TDBComboBox   Найти похожие ветки 

 
Ral'f   (2007-06-13 19:57) [0]

Мастера, прошу вашей помощи, не нашёл хорошего описания компонента TDBComboBox! Работаю с MS Access, нужно, чтобы в одном из компонентов можно было выбрать одну из имеющихся в колонке записей (причём в колонке записи могут повторяться, а в ComboBox это, конечно, не желательно), или добавить свою. Как подключить TDBComboBox к своей таблице? Или лучше для этого использовать обычный TComboBox?


 
ЮЮ ©   (2007-06-14 04:12) [1]

> причём в колонке записи могут повторяться, а в ComboBox
> это, конечно, не желательно),


запросом выбрать неповторяющиеся значения и заполнить ими Items.


> или добавить свою

TDBComboBox позволяет вводить любое значение, не только из списка. В AfterPost, например, можно убедиться есть ли значение поля в Items, если нет - добавить в Items.


 
ЮЮ ©   (2007-06-14 06:25) [2]

>не нашёл хорошего описания компонента TDBComboBox!

А чего там описывать? Обычный TDBЕdit, у которого есть выпадающий список для облегчения ввода длинных строк. Выпадающий список должен формироваться программно, компонент им не управляет.


 
ASoft   (2007-06-14 07:34) [3]


> Ral"f   (13.06.07 19:57)

TDBLookUpComboBox мож, лучше подойдет?


 
ЮЮ ©   (2007-06-14 08:13) [4]

> TDBLookUpComboBox мож, лучше подойдет?


TDBLookUpComboBox хорош, когда имеем дело с справочной таблицей.


 
Ral'f   (2007-06-14 09:58) [5]

> ЮЮ ©   (14.06.07 04:12) [1]
>запросом выбрать неповторяющиеся значения и заполнить ими Items.


я предполагал сделать так:
TADOTable(Tabl).First;
TDBComboBox(Sender).Items.Clear;
while not TADOTable(Tabl).Eof do
begin
s:=TADOTable(Tabl).Fields[Nom].AsString;
if (TDBComboBox(Sender).Items.IndexOf(s)<0) and (s<>"")
 then TDBComboBox(Sender).Items.Add(s);
TADOTable(Tabl).Next;
end;
TADOTable(Tabl).First;


А как это сделать с помощью запроса?


 
ЮЮ ©   (2007-06-14 10:18) [6]

> А как это сделать с помощью запроса?


adoQuery.Text := "SELECT DISTINCT <Имя поля> FROM <имя таблицы> WHERE <Имя поля> IS NOT NULL";
adoQuery.Open;
while not adoQuery.EOF do begin
 TDBComboBox(Sender).Items.Add(adoQuery.Fields[0].asString);
 adoQuery.Next;
end;


На худой конец, сойдет и твое [5] :)


 
Ral'f   (2007-06-14 10:22) [7]

Огромное спа"си"бо"!!!


 
ЮЮ ©   (2007-06-14 10:29) [8]

p.s. adoQuery.Text := "SELECT DISTINCT <Имя поля> FROM <имя таблицы> WHERE <Имя поля> IS NOT NULL ORDER BY 1";


 
Anatoly Podgoretsky ©   (2007-06-14 12:43) [9]

Для начала забудь про это TADOTable, а потом про это TAdoQuery и используй TAdoDataset



Страницы: 1 вся ветка

Текущий архив: 2007.07.08;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.021 c
2-1181928234
alpha5
2007-06-15 21:23
2007.07.08
Как показать форму аналогично PopupMenu


2-1181889608
Баян 555
2007-06-15 10:40
2007.07.08
перевод в читабельный вид


3-1176381602
svt
2007-04-12 16:40
2007.07.08
Уважаемы мастера,подскажите что может быть с соединением


1-1178612822
nali
2007-05-08 12:27
2007.07.08
Обмен значениями между потоками


1-1178448538
a125
2007-05-06 14:48
2007.07.08
Перенос слова в TQRLabel