Example #1
0
        /// <summary>
        /// 执行SQL语句返回结果到DataTable中
        /// </summary>
        /// <param name="strSQL"></param>
        /// <returns></returns>
        public DataTable ExecuteDataTable(string strSQL)
        {
            int begintime = Environment.TickCount;

            databaseMutex.WaitOne();

            DataTable table;

            try
            {
                if (mysqlConnection.State == ConnectionState.Closed)
                {
                    mysqlConnection.Open();
                }

                table = new DataTable();

                MySqlDataAdapter dbda = new MySqlDataAdapter(strSQL, mysqlConnection);

                dbda.Fill(table);
            }
            catch (Exception e)
            {
                CLog4net.LogError(strSQL + " " + e);
                return(null);
            }
            finally
            {
                databaseMutex.ReleaseMutex();
                mysqlConnection.Close();
            }
            CLog4net.LogInfo(strSQL + " 执行结束:" + (Environment.TickCount - begintime) + "ms");
            return(table);
        }
Example #2
0
        /// <summary>
        /// 执行SQL语句没有返回结果,如:执行删除、更新、插入等操作
        /// </summary>
        /// <param name="strSQL"></param>
        /// <returns>操作成功标志</returns>
        public bool ExecuteNonQuery(string strSQL)
        {
            int begintime = Environment.TickCount;

            databaseMutex.WaitOne();

            bool resultState = false;

            if (mysqlConnection.State != ConnectionState.Open)
            {
                mysqlConnection.Open();
            }

            MySqlTransaction myTrans = mysqlConnection.BeginTransaction();//不支持并行用户
            MySqlCommand     command = new MySqlCommand(strSQL, mysqlConnection, myTrans);

            try
            {
                command.ExecuteNonQuery();
                myTrans.Commit();
                resultState = true;
            }
            catch (Exception e)
            {
                myTrans.Rollback();
                resultState = false;
                CLog4net.LogError(strSQL + " " + e);
            }
            finally
            {
                databaseMutex.ReleaseMutex();
                mysqlConnection.Close();
            }

            CLog4net.LogInfo(strSQL + " 执行结束:" + (Environment.TickCount - begintime) + "ms");
            return(resultState);
        }