Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности

Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
22.04.2005, 19:22
|
|||
|---|---|---|---|
|
|||
asa esql+thread |
|||
|
#18+
hi all знает ли кто как использовать esql в safethread'ax? по документации If more than one thread uses the same SQLCA, a context option can cause more than one thread to be using the SQLCA at the same time. Each thread must have its own SQLCA. возникает мысль, что при наличии SQLCA в каждом треде и подключении reentrant библиотек наступает тот самый safe, однако это не так. треды висят на Attempted two active database requests. если обложить мутексами все работает. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
22.04.2005, 21:20
|
|||
|---|---|---|---|
asa esql+thread |
|||
|
#18+
Очень похоже, что ты делаешь делаешь несколько SQLCA на один коннект. Угадал? :) ASA не умеет делать несколько разных запросов внутри одного сеанса. Надо сначала сделать несколько SQLCA, потом каждый из них самостоятельно подключить к базе. Тогда и получится нормальная асинхронность. А так у тебя получается просто несколько описаний одного и того же сеанса. Соответственно при обращении к одному из SQLCA ты блокируешь все остальные. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
23.04.2005, 13:19
|
|||
|---|---|---|---|
|
|||
asa esql+thread |
|||
|
#18+
насколько я понимаю, это SQLCA на каждый конект. например так void *thread(void *smth) { exec sql include sqlca; db_init(&sqlca); exec sql connect.... exec sql select... .... db_fini(&sqlca); .... } ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
25.04.2005, 17:37
|
|||
|---|---|---|---|
asa esql+thread |
|||
|
#18+
bindtoнасколько я понимаю, это SQLCA на каждый конект. например так void *thread(void *smth) { exec sql include sqlca; db_init(&sqlca); exec sql connect.... exec sql select... .... db_fini(&sqlca); .... } Не совсем :) Этот код будет расшифрован на этапе компиляции, и ты получишь один общий статичный SQLCA объект в DATA сегменте. Тебе нужно объяснить препроцессору, что надо создавать несколько SQLCA в рантайме. Это делается командой SET SQLCA. Загляни в BOL, в главы Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=55&tablet=1&tid=2013686]: |
0ms |
get settings: |
9ms |
get forum list: |
21ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
61ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
41ms |
get tp. blocked users: |
1ms |
| others: | 266ms |
| total: | 417ms |

| 0 / 0 |
