I've come from Java experience and am trying to start with C#. I've read SqlConnection SqlCommand SqlDataReader IDisposable and I can understand that the best practice to connecting to a DB is wrapping SqlConnection
, SqlCommand
and SqlDataReader
in their own using
block.
But in Java we use to encapsulate the connection into a factory method, create it only once, and reuse it for all queries, even multithreaded ones. Only statements and result sets are created for each query and closed ASAP.
Isn't creating a new SqlConnection
for each query kinda overkill? Can't it be reused?
Creating a new instance of the class
SqlConnection
does not create a new network connection to SQL Server, but leases an existing connection (or creates a new one). .NET handles the physical connection pooling for you.When you have finished with your connection (through which you can send multiple queries) just
Close()
orDispose()
(or use ausing{}
block preferably).There is no need, and not good practise, to cache instances of the
SqlConnection
class.To answer your specific question, you can reuse a
SqlConnection
for each query. Just make sure to close your current query (SqlDataReader
, etc.) before you run another one, ie. wrap them in their ownusing
blocks.Yes, you can create a global SqlConnection instance. In my case I use the SqlConnection as member of my DataContext that I access via Singleton.
You can encapsulate your transactions by closing and opening this connection, i.e.:
Or you might leave the connection open, but instead specifically begin and end transactions:
As VMAtm has said, .net Pools the connections on it's own, so it is perfectly ok to recreate them. As such I generally write a wrapper for the whole process like this one.
MS SQL server manages connections in it's own connection pool, and they aren't actually disposed. But they are closed so you minimize the network traffic and release the available connections to your server.
Also you should note that if you are using the Linq-To-SQL, the data context will not release the connection until being disposed, so I suggest you just use already working code and do not try to optimize it by yourself.