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

Вниз

Как отобразить список записей поля таблицы в combobox?   Найти похожие ветки 

 
Bormanoid ©   (2002-02-07 21:25) [0]

Очень признателен!


 
Gregory   (2002-02-08 08:35) [1]

Если DataSet уже есть (Query или Table, например), то используй DBLookupComboBox - там можно задать и отображаемое, и ключевое поля. Или:

with ComboBox1 do
begin
Items.Clear;
DataSet.First;
for i := 1 to DataSet.RecordCount do
begin
Items.Add( DataSet[ "<field to view>" ] );
DataSet.Next;
end;
end;


 
Johnmen ©   (2002-02-08 11:43) [2]

>Gregory :
with ComboBox1 do
begin
Items.Clear;
DataSet.First;
while not DataSet.Eof do
begin
Items.Add( DataSet[ "<field to view>" ] );
DataSet.Next;
end;
end;



 
Alexandr ©   (2002-02-08 11:50) [3]

дык это же один хер.
Просто в первом случае записи фетчатся сразу( при recordcount)
а во втором случае постепенно по мере next.

Другое дело, что некоторые компоненты доступа (к BDE это не относится) могут неправильно посчитать recordCount (по крайней мере пока FetchAll не сделать или Last). Но это частности.

Кстати, даже если компоненты будут считать RecordCount только отфетченных записей (так делает например FIBPlus), то первый вариант все равно выполнится правильно. Т.к. сначала RecordCount будет равен 1, а потом с каждым next он будет возрастать на 1, пока до конца выборки не дойдет.


Вот такой вот полный ответ.


 
Johnmen ©   (2002-02-08 11:57) [4]

>Alexandr © : А кто говорит, что неправильно ? Просто второй пример - более грамотно.


 
Alexandr ©   (2002-02-08 12:01) [5]

в чем выражается "более грамотно".
Можно в двух словах?


 
Johnmen ©   (2002-02-08 12:12) [6]

>Alexandr © :

1. сарказм неуместен
2. ...Другое дело, что некоторые компоненты доступа (к BDE это не относится) могут неправильно посчитать recordCount (по крайней мере пока FetchAll не сделать или Last). Но это частности...
3. не надо заводить i : integer;



 
Bormanoid ©   (2002-02-08 12:22) [7]

Как юзать OnChange событие в ComboBox в такой ситуации?
А как можно прочитать выбранный елемент?


 
Johnmen ©   (2002-02-08 12:31) [8]

procedure TForm1.ComboBox1Change(Sender: TObject);
begin
Label1.Caption:=ComboBox1.Text;
end;


 
Alexandr ©   (2002-02-08 12:36) [9]

2Johnmen
понял. Вообщем согласен.


 
Bormanoid ©   (2002-02-08 12:37) [10]

Johnmen>
У меня в ComboBox не меняеться запись в ComboBox1? Как сменить при OnChange(на выбраную)?


 
Alexandr ©   (2002-02-08 12:40) [11]

Она сама изменится если у тебя у Combobox1 ReadOnly не стоит.


 
Bormanoid ©   (2002-02-08 12:49) [12]

У меня в ComboBox.ReadOnle:=false;


 
Alexandr ©   (2002-02-08 12:52) [13]

слушай, а компонент у тебя какой? Точно Tcombobox?



 
Bormanoid ©   (2002-02-08 12:55) [14]

Ой-ой-ой!
Блин!
У меня DBComboBox....


 
Alexandr ©   (2002-02-08 12:59) [15]

я так и думал..!


 
Bormanoid ©   (2002-02-08 12:59) [16]

Спасибо!
Я просто сменил DBComboBox на простой СomboBox и все ОКЕЙ.
Но почему же DBComboBox не меняет...


 
Alexandr ©   (2002-02-08 13:02) [17]

а потому что ты ему не задал кокое ему поле менять, он же значение из этого поля берет, а раз поля нет, то и выбранного значения нет.
Тут как говорится "No pay -no game"



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

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

Наверх




Память: 0.5 MB
Время: 0.012 c
3-19104
tovSuhov
2002-02-11 11:40
2002.03.07
Набор команд SQL


1-19243
DimaIv
2002-02-18 14:38
2002.03.07
Как в Delphях во вкладку Help запихать Win32 SDK


3-19085
fag2000@ok.ru
2002-02-07 14:08
2002.03.07
Проблема с TDBGrid


7-19360
denis2001
2001-12-03 17:53
2002.03.07
Информация о системе( нужен модуль CRT.DCU или WINCRT.DCU


6-19280
Andrey Lutsenko
2001-12-10 05:58
2002.03.07
OS Version of remote comp