Войти в систему

Home
    - Создать дневник
    - Написать в дневник
       - Подробный режим

LJ.Rossia.org
    - Новости сайта
    - Общие настройки
    - Sitemap
    - Оплата
    - ljr-fif

Редактировать...
    - Настройки
    - Список друзей
    - Дневник
    - Картинки
    - Пароль
    - Вид дневника

Сообщества

Настроить S2

Помощь
    - Забыли пароль?
    - FAQ
    - Тех. поддержка



Пишет ringill ([info]ringill)
@ 2007-07-23 19:45:00

Previous Entry  Add to memories!  Tell a Friend!  Next Entry
Малоинтересная деталь в .NET
Класс OracleCommand при выполнении запроса INSERT выделяет курсор в Oracle, который не освобождает при вызове Dispose().
OracleCommand cmd = new OracleCommand("INSERT INTO ...", connection);

try
{
  cmd.ExecuteNonQuery();
}
finally
{
  cmd.Dispose();
}
При многократном выполнении приведённого куска в цикле у Oracle быстро кончается пул курсоров, что приводит к ошибке ExecuteNonQuery(). Выделенные курсоры можно подсмотреть с помощью запроса

select user_name, status, osuser, machine, a.sql_text from v$session b, v$open_cursor a where a.sid = b.sid

Высвободить курсор(ы) помогает принудительная сборка мусора:
cmd = null;
System.GC.Collect();


(Читать комментарии)

Добавить комментарий:

Как:
(комментарий будет скрыт)
Identity URL: 
имя пользователя:    
Вы должны предварительно войти в LiveJournal.com
 
E-mail для ответов: 
Вы сможете оставлять комментарии, даже если не введете e-mail.
Но вы не сможете получать уведомления об ответах на ваши комментарии!
Внимание: на указанный адрес будет выслано подтверждение.
Имя пользователя:
Пароль:
Тема:
HTML нельзя использовать в теме сообщения
Сообщение: