I'm working with a program coded in C++ which uses ODBC on SQL Native Client to establish connections to interact with a SQL Server 2000 database.
My connections are abstracted into an object which opens a connection when the object is instantiated and closes the connection when the object is destroyed. I can see that the objects are being destroyed: their destructor are firing and inside of these destructors,
SQLDisconnect( ConnHandle ) is being called, followed by
SQLFreeHandle( SQL_HANDLE_DBC, ConnHandle ); However, watching the connection count using
sp_Who2 or the Performance Monitor in SQL shows the connection count increasing without relent, despite these connections being destroyed.
This hasn't proven problematic until executing a chain of functions that runs long enough to create several thousand of these objects and as such, several thousands of connections.
Has anyone seen anything like this before? What might be causing this? My initial google searches haven't proven very fruitful!
I have verified that
SQLDisconnect is returning without error.
Connection pooling is off. In fact, when I attempt to enabling it using
SQLSetEnvAttr, my application crashes when the 2nd call to
SQLDriverConnect is made.