Passing around a SqlConnection

前端 未结 4 1429
花落未央
花落未央 2021-01-25 13:09

I have created a TransactionScope and within the scope various items are created and updated in the database. During this process I make a lot of calls to the database. Original

相关标签:
4条回答
  • 2021-01-25 13:35

    I tend to avoid passing connections around at all cost. I've just seen too many errors creep into a system when someone else, for example, closes a connection in the middle of a sequence of operations because they didn't know others were going to use the same connection.

    Creating a SQLConnection is almost free due to ADO.NET's connection pooling mechanisms so don't think you're going to save any space/time by creating one and passing it around.

    If, as in your situation, you truly do need to perform a number of DB operations within a transaction scope, then manage your scope appropriately, but create, use and dispose of your connections as and when you need them - it'll help keep your code A LOT cleaner and safer.

    0 讨论(0)
  • 2021-01-25 13:51

    If you're going to make a lot of calls in a row, and it's easy to pass in an open connection, then yes, reuse the open connection.

    This is not incredibly important though. Not as much as it used to be. ADO.NET does a good job of managing this for you. See Connection Pooling. If your code is going to get complicated and weird to facilitate one single, open connection object, it's not worth it.

    (Now, making sure your connection objects (whether reused or not) are disposed of is of course really important, as I bet you already know.)

    0 讨论(0)
  • 2021-01-25 13:51

    In general I would agree with what others have said. Note however, that once you use multiple connections inside a single TransactionScope instance, it will promote your (local) transaction to a distributed one, thus incurring some possibly significant overhead.

    Multiple connections from the same pool, thus using the same database, also count as multiple connections in this sense.

    If that is an issue for you, versus code structure or "cleanness", typical SQL statement execution time, etc., you need to decide.

    0 讨论(0)
  • 2021-01-25 13:51

    Anyway if want to have several connections to DB use connection pool.

    0 讨论(0)
提交回复
热议问题