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

Вниз

ComboBox и Базы данных   Найти похожие ветки 

 
beglec ©   (2006-04-03 15:57) [0]

Пример:

База данных имеет 10 значений.
Сормировался CB по выборке из базы. Всего 3 значения. Значение формируется сложно Типа: Ф+И+О+кв.+машина+картонка.
Пользователь выбрал какое либо из предложенных значений.

Требуется перейти на нужную запись взависимости от выбранного пункта в CB.

Разбирать обратно сформированное значение долго и глупо!
В данный момент я формирую отдельный массив
Типа
ID - Integer;
Text - String;

string отображаю - а по ID перехожу по записям в таблице
Но это сложно, но легче чем первый вариант, типа создать массив, сформировать, формировать CB, освободить память CB и тд. другие проблемы связанные с этим.

А другой способ, попросче есть?
Типа что то Items[0].Tag  или в таком же духе?
Как можно обыграть такую ситуацию?

P.S. CB- ComboBox


 
Sergey13 ©   (2006-04-03 16:07) [1]

2 beglec ©   (03.04.06 15:57)
Есть еще DBComboBox и DBLookupComboBox. Почему бы ими не воспользоваться?


 
Johnmen ©   (2006-04-03 16:08) [2]

ComboBox.AddItem("xxx",pointer(<тут твой ID для пункта CB>));

А ежели более одной записи по конкретному  Ф+И+О+кв.+машина+картонка ?


 
beglec ©   (2006-04-03 16:16) [3]


> Johnmen ©

не используется по многим соображениям, а главное - нет прямой связи с DB есть только инфа о записи и ее ID


> DBComboBox

одна запись = одной записи
по крайней мере пока так обстоит дело.


ComboBox.AddItem("xxx",pointer(<тут твой ID для пункта CB>));

А как потом от туда читать ?


 
Johnmen ©   (2006-04-03 16:39) [4]


> А как потом от туда читать ?


ComboBox.AddItem + F1


 
Vlad ©   (2006-04-03 16:56) [5]


> beglec ©   (03.04.06 16:16) [3]


Добавить в комбобокс:

var
 P: PInteger;
....

 New(P);
 P^ := <ID_записи_типа_integer>;
 ComboBox.AddItem("Ф+И+О+кв.+машина+картонка", TObject(P));


Считать из комбобокса:

 ID := PInteger(ComboBox.Items.Objects[i])^;

Не забыть при закрытии формы освободить память из-под указателей


 
beglec ©   (2006-04-03 16:58) [6]


> Vlad ©

спасибо
а то я из справки ничего не понял !


 
Johnmen ©   (2006-04-03 17:21) [7]


> Vlad ©   (03.04.06 16:56) [5]


Не, так крутить я бы не стал. Не тот случай...
CB.AddItem("xxx", pointer(ID));
ID:=integer(CB.Items.Objects[i]);


 
Vlad ©   (2006-04-03 17:26) [8]


> Johnmen ©   (03.04.06 17:21) [7]


> pointer(ID)


а что тогда ID в данном случае? Локальная переменная, глобальная или поле класса? Т.е. нужны какие-то гарантии что она не убьется в памяти раньше времени...


 
Johnmen ©   (2006-04-03 17:34) [9]


> Vlad ©   (03.04.06 17:26) [8]
> а что тогда ID в данном случае? Локальная переменная, глобальная
> или поле класса? Т.е. нужны какие-то гарантии что она не
> убьется в памяти раньше времени...


ID - integer переменная.
Её значение, приведённое к поинтеру, записано в поле айтема объекта TStrings.
Убьётся вместе с убиением айтема. Раньше не получится... :)


 
Vlad ©   (2006-04-03 18:00) [10]


> Johnmen ©   (03.04.06 17:34) [9]


А, ну да, ты ж не указатель пишешь а саму переменную. Перепутал.

Зато [5] способ годится не только для Integer, но и для Double и других типов (это я автору) :-)



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

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

Наверх




Память: 0.47 MB
Время: 0.009 c
2-1147277350
Nicky
2006-05-10 20:09
2006.05.28
Как запаролить форму


15-1146750860
acL
2006-05-04 17:54
2006.05.28
Как установить игру


2-1147198249
Firefly
2006-05-09 22:10
2006.05.28
TFileStream


2-1147372407
ribbon
2006-05-11 22:33
2006.05.28
Проект, наподобие IBExpert


2-1146837440
Dr. Genius
2006-05-05 17:57
2006.05.28
Поиск строк в Pas-модуле Delphi





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский