|
|
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
Есть ComboBox, который я заполняю записями из таблицы. У таблицы всего два поля: Nik (текст, который виден в ComboBox-е) и Id (ключ, который используется для связи с другими таблицаими). Просытм select-ом открываю Recordset, бегу по нему и заполняю ComboBox двумя командами: AddString() и SetItemData(). Вроде жил и не тужил, всё замечательно работало, пока количество записей в таблице не подобралось к 2000. ComboBox заполняется секунд пять. Задержка очень злит пользователей. Подскажите, как побороть? Какие варианты кто использует? Пишу на VC 6.0, MFC. Заранее спасибо за любые советы, предложения и ссылки. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 12:52 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
А выбор из 2000 не злит пользователей? По моему нужно выбирать иерархически, например вместо Combo простое поле, кнопка "Выбор" по нажатии окно с двумя и более таблицами и каскадный выбор. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 14:40 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
Да это названия улиц. Какую там иерархию придумаешь? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 16:23 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
BigBobДа это названия улиц. Какую там иерархию придумаешь? по 1 букве ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 17:48 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
Типа на OnChange() повеситься и подгружать улицы, начинающиеся с нужной буквы? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 19:29 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
Типа на OnChange() повеситься и подгружать улицы, начинающиеся с нужной буквы? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 19:30 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
Ладно уж, пожалею тебя. Магическое заклинание называется CB_INITSTORAGE. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 19:57 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
Обижаешь ;) Попробовал я конечно вызывать функцию InitStorage() перед тем как заполнять ComboBox. Выигрышь по скорости заполнения есть, но совсем копеечный ;( ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 20:23 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
На старте программы заглоти его в память. Теже 5 сек на старте не так ощутимы. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.02.2005, 21:45 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
Основное время тратится именно на заполнение ComboBox-а. Тоесть recodset открывается практически мгновенно. 90% времени тратится именно на цикл: Код: plaintext 1. 2. 3. 4. 5. 6. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 26.02.2005, 12:09 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
Разбей этот цикл на два Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. И посмотри какой больше времени сжигает. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 26.02.2005, 16:02 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
У меня была подобная прблема. Решил следующим образом (может и культяписто): имеется поле (Edit), в котором вводится некоторый контекст (ну, там, первые буквы, к примеру), далее нажимается "волшебная" кнопка (можно и клавишу какую-нибудь подключить) по которой выводится список значений, начинающихся с введенного контекста. Пользователь выбирает нужное значение из этого списка (список уже не такой большой). Список можно сделать тем же ComboBox'ом... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 28.02.2005, 11:16 |
|
||
|
ComboBox из таблицы
|
|||
|---|---|---|---|
|
#18+
BigBobОбижаешь ;) Попробовал я конечно вызывать функцию InitStorage() перед тем как заполнять ComboBox. Выигрышь по скорости заполнения есть, но совсем копеечный ;( Знаешь , там еще параметры всякие есть ... Значит так вот и вызывал. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 28.02.2005, 18:34 |
|
||
|
|

start [/forum/topic.php?fid=57&msg=32933657&tid=2033674]: |
0ms |
get settings: |
10ms |
get forum list: |
20ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
36ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
66ms |
get tp. blocked users: |
1ms |
| others: | 225ms |
| total: | 381ms |

| 0 / 0 |
