Correct use of connections with C# and MySQL

前端 未结 2 1320
無奈伤痛
無奈伤痛 2021-01-21 08:13

A typical example for C#/MySQL interaction involves code like this (I\'m skipping try/catches and error checking for simplicity\'s sake):



        
相关标签:
2条回答
  • 2021-01-21 08:46

    To expand on HackedByChinese's recommendation consider the following. You have one main coordinating method that handles creating the connection, opening it, setting the transaction, and then calling the worker methods that do the different types of work (queries).

      public static void UpdateMyObject(string connection, object myobject)
            {
            try
            {
                using (SqlConnection con = new SqlConnection(connection))
                {
                    con.Open();
                    using (SqlTransaction trans = con.BeginTransaction())
                    {
                        WorkingMethod1(con, myobject);
                        WorkingMethod2(con, myobject);
                        WorkingMethod3(con, myobject);
                        trans.Commit();
                    }
                    con.Close();
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show("SOMETHING BAD HAPPENED!!!!!!!  {0}", ex.Message);
            }
        }
    
        private static void WorkingMethod1(SqlConnection con, object myobject)
        {
            // Do something here against the database
        }
    
        private static void WorkingMethod2(SqlConnection con, object myobject)
        {
            // Do something here against the database
        }
    
        private static void WorkingMethod3(SqlConnection con, object myobject)
        {
            // Do something here against the database
        }
    
    0 讨论(0)
  • 2021-01-21 08:54

    You typically want to open one connection per unit of work. The MySQL ADO.NET driver can pool connections for you, however, I would recommend against having each query open a connection. What can happen is you start using several methods in order to service one business transaction, and since each is opening a connection, you can end up that one business transaction starving your available connections. This of course can lead to timeouts, poor performance, etc.

    Instead, consider defining an IUnitOfWork/UnitOfWork API that creates and opens a connection and transaction, and having your data access layer request the current IUnitOfWork, which will provide the current connection and transaction.

    The trick, of course, is knowing when a unit of work begins and when it ends. They are associated with a complete, meaningful action (a "business transaction"). For example, when you are servicing a request to a method on one of your WCF services. When the service instance starts, in response to a request, a unit of work should be created. Then you DAL components can ask for the current unit of work and use it. Then when the request is completed, the unit of work should be committed (which should commit the transaction and close the connection).

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