Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Подключение через ODBC API. ODBC 2.x application 
:(
    Опции темы
Sharl
Дата 7.9.2004, 17:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 32
Регистрация: 16.8.2003

Репутация: нет
Всего: нет



у меня проблема такого типа.

Для подключения к базе нужно
Код

 HENV FAR   henv = SQL_NULL_HENV;
 HDBC FAR   hdbc = SQL_NULL_HENV;

 SQLAllocEnv( &henv );                    //инициализировать handle
 SQLAllocConnect( henv, &hdbc );   //и соединиться

а для окончания сеанса
Код

SQLFreeConnect( hdbc );
SQLFreeEnv( henv );

Проблема в чем.
После

SQLFreeEnv( henv );

память не освобождается.Это точно. Следил в Task Manager.
Т.е. если в одном приложении много раз вызвать пару

SQLAllocEnv( &henv );
SQLFreeEnv( henv );


то никакой Free памяти не делается.
Приходится на каждое приложение при старте только один раз вызвать

SQLAllocEnv( &henv );

а при закрытии приложения

SQLFreeEnv( henv );

Особо подчеркну (и что самое ужасное), что если в разных потоках (или вообще в разных местах) надо держать разные henv, то ничего не получается, поскольку при следующем вызове

SQLAllocEnv( &henv );

на уровне приложения сохраняется только один действующий henv.

Но о таком поведении ничего не говорится в help-ах ODBC API.

Не знаю,что и делать - тут баг на уровне API функции,или я что-то не то делаю?




PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0773 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.