|
Много штук m_pDatabase. Плохо ?
|
|||
---|---|---|---|
#18+
Раньше всегда делал так: одна m_pApp->m_pDatabase, во всех вьюшках new CRecordset(m_pApp->m_pDatabase). Сейчас: К вьюшке леплю диалог(докед) в котором отображаю дополнительные свойства выбраной во вьюшке(где стоит курсор) записи. Все бы ничего, но ежели во вьюшке выборка ~200k записей то при открытии вьюшки драйвер высасывает к себе на винт всю выборку ~100M(вследствии чего тормозит), а затем тока заполняет окошко в диалоге свойствами выбраной записи. Я так понимаю, что если использовать одну CDatabase, то если он(драйвер) при первом фитче не вытащил все, и я обращаюсь через тотже CDatabase к другой выборке, то он чтобы освободить HSTMT выбирает остаток, а потом запрашивает вторую выборку. Раньше было еще хуже - при открытии второй выборки он вываливал ехепшон и орал что хстмт занят, но я потом чтото сделал(кажется обновил мсдак) и он вот так теперь поступает. Мне все это не нравится, поэтому гдето месяц назад я, практически, к каждому рекордсету прикрутил по датабазе. Ничего не тормозит все работает прекрасно, но... Этот месяц я плохо сплю ибо грызет меня червяк сомнения, что для каждого рекордсета по датабазе это плохо. Почему плохо - обосновать себе немогу. (MSSQL, VC6) Скажите почему это плохо, или разубедите меня пжалуйста. Если есть другой метод решенимя этой проблемы - подскажите где копать ... |
|||
:
Нравится:
Не нравится:
|
|||
11.02.2003, 17:30 |
|
Много штук m_pDatabase. Плохо ?
|
|||
---|---|---|---|
#18+
Выражу свое мнение - это довольно безграмотный вариант! Для каждого рекордсета драйвер ODBC создает новое соединение ( что влияет на производиетльность и ресурсы сервера) - допустим в программе 10 рекордсетов, 50 пользовоателей - получаем 500 соединений. Кроме того уровень транзакций живет в Database и это значит что рано или поздно последовательность каких то дейтвий будут выполнена таким образом, что ошибка в одном из шагов не вызовет отката всей цепочки - будет нарушена целстность данных. То есть такой подход сразу в себе содержит два серьезных недостатка - ресуросоемкий и не обеспечивает надежность работы приложения и целостность данных. Думайте. ... |
|||
:
Нравится:
Не нравится:
|
|||
12.02.2003, 12:21 |
|
Много штук m_pDatabase. Плохо ?
|
|||
---|---|---|---|
#18+
Так как же, блин, быть ??? 8-( ... |
|||
:
Нравится:
Не нравится:
|
|||
12.02.2003, 13:04 |
|
Много штук m_pDatabase. Плохо ?
|
|||
---|---|---|---|
#18+
Для быстрого считывания данных из базы ( для просмотра) рекомендую использовать Bulk рекордсет - конечно прийдется поводится - но скорость считывания впечатляет! ... |
|||
:
Нравится:
Не нравится:
|
|||
12.02.2003, 13:08 |
|
Много штук m_pDatabase. Плохо ?
|
|||
---|---|---|---|
#18+
Это я попробую. Спасибо. Но есть же еще такой момент: Кода драйвер хочет освободить HSTMT, он вытягивает все к себе на винт, создавая этим самым сотни-метровый файл в темпе, а на WSах с винтами на 5400 это оч даже заметно. Все это не радует... ... |
|||
:
Нравится:
Не нравится:
|
|||
14.02.2003, 11:35 |
|
|
start [/forum/topic.php?fid=57&msg=32104728&tid=2036436]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
29ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
41ms |
get tp. blocked users: |
2ms |
others: | 275ms |
total: | 393ms |
0 / 0 |