侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

微软官方SqlHelper类 数据库辅助操作类 原创

数据库  /  管理员 发布于 5年前   606

数据库操作类真的没有必要自己去写,因为成熟的类库真的非常完善了,拿来直接用就好,省时省力。

本文就为大家介绍微软官方的程序PetShop4.0中的SqlHelper类,先来做一下简单的介绍,PetShop是一个范例,微软用它来展示.Net企业系统开发的能力。

那SqlHelper中封装了哪些方法呢?

里面的函数一堆,常用的就那几个,无非就是增删改查嘛,来看下几种常用的函数:

1.ExecuteNonQuery 执行增删改
2.ExecuteReader 执行查询
3.ExecuteScalar 返回首行首列

使用方法介绍

Web.config配置

<connectionStrings><add name="ConnectionString" connectionString="server=127.0.0.1;uid=sa;pwd=ok;database=PetShop;Max Pool Size =512; Min Pool Size=0; Connection Lifetime = 300;packet size=1000;" providerName="System.Data.SqlClient" /></connectionStrings>

调用函数的写法

sql = "UPDATE Student set Name = @Name WHERE Id = @Id";SqlHelper.ExecuteNonQuery(CommandType.Text, sql, new SqlParameter[]{ new SqlParameter("@Name", name), new SqlParameter("@Id", id)});

这样调用就比较简化,而且比较灵活

源码呈上

/// <summary>  /// The SqlHelper class is intended to encapsulate high performance,   /// scalable best practices for common uses of SqlClient.  /// </summary>  public abstract class SqlHelper  {    //数据库连接字符串    public static readonly string ConnectionString = ConfigurationManager.ConnectionStrings["SQLConnString"].ConnectionString;    #region 私有函数和方法    /// <summary>    /// This method is used to attach array of SqlParameters to a SqlCommand.    ///     /// This method will assign a value of DbNull to any parameter with a direction of    /// InputOutput and a value of null.     ///     /// This behavior will prevent default values from being used, but    /// this will be the less common case than an intended pure output parameter (derived as InputOutput)    /// where the user provided no input value.    /// </summary>    /// <param name="command">The command to which the parameters will be added</param>    /// <param name="commandParameters">An array of SqlParameters to be added to command</param>    private static void AttachParameters(SqlCommand command, SqlParameter[] commandParameters)    {      if (command == null) throw new ArgumentNullException("command");      if (commandParameters != null)      {        foreach (SqlParameter p in commandParameters)        {          if (p != null)          {            // Check for derived output value with no value assigned            if ((p.Direction == ParameterDirection.InputOutput ||              p.Direction == ParameterDirection.Input) &&              (p.Value == null))            {              p.Value = DBNull.Value;            }            command.Parameters.Add(p);          }        }      }    }    /// <summary>    /// This method assigns dataRow column values to an array of SqlParameters    /// </summary>    /// <param name="commandParameters">Array of SqlParameters to be assigned values</param>    /// <param name="dataRow">The dataRow used to hold the stored procedure's parameter values</param>    private static void AssignParameterValues(SqlParameter[] commandParameters, DataRow dataRow)    {      if ((commandParameters == null) || (dataRow == null))      {        // Do nothing if we get no data        return;      }      int i = 0;      // Set the parameters values      foreach (SqlParameter commandParameter in commandParameters)      {        // Check the parameter name        if (commandParameter.ParameterName == null ||          commandParameter.ParameterName.Length <= 1)          throw new Exception(            string.Format(              "Please provide a valid parameter name on the parameter #{0}, the ParameterName property has the following value: '{1}'.",              i, commandParameter.ParameterName));        if (dataRow.Table.Columns.IndexOf(commandParameter.ParameterName.Substring(1)) != -1)          commandParameter.Value = dataRow[commandParameter.ParameterName.Substring(1)];        i++;      }    }    /// <summary>    /// This method assigns an array of values to an array of SqlParameters    /// </summary>    /// <param name="commandParameters">Array of SqlParameters to be assigned values</param>    /// <param name="parameterValues">Array of objects holding the values to be assigned</param>    private static void AssignParameterValues(SqlParameter[] commandParameters, object[] parameterValues)    {      if ((commandParameters == null) || (parameterValues == null))      {        // Do nothing if we get no data        return;      }      // We must have the same number of values as we pave parameters to put them in      if (commandParameters.Length != parameterValues.Length)      {        throw new ArgumentException("Parameter count does not match Parameter Value count.");      }      // Iterate through the SqlParameters, assigning the values from the corresponding position in the       // value array      for (int i = 0, j = commandParameters.Length; i < j; i++)      {        // If the current array value derives from IDbDataParameter, then assign its Value property        if (parameterValues[i] is IDbDataParameter)        {          IDbDataParameter paramInstance = (IDbDataParameter)parameterValues[i];          if (paramInstance.Value == null)          {            commandParameters[i].Value = DBNull.Value;          }          else          {            commandParameters[i].Value = paramInstance.Value;          }        }        else if (parameterValues[i] == null)        {          commandParameters[i].Value = DBNull.Value;        }        else        {          commandParameters[i].Value = parameterValues[i];        }      }    }    /// <summary>    /// This method opens (if necessary) and assigns a connection, transaction, command type and parameters     /// to the provided command    /// </summary>    /// <param name="command">The SqlCommand to be prepared</param>    /// <param name="connection">A valid SqlConnection, on which to execute this command</param>    /// <param name="transaction">A valid SqlTransaction, or 'null'</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParameters to be associated with the command or 'null' if no parameters are required</param>    /// <param name="mustCloseConnection"><c>true</c> if the connection was opened by the method, otherwose is false.</param>    private static void PrepareCommand(SqlCommand command, SqlConnection connection, SqlTransaction transaction, CommandType commandType, string commandText, SqlParameter[] commandParameters, out bool mustCloseConnection)    {      if (command == null) throw new ArgumentNullException("command");      if (commandText == null || commandText.Length == 0) throw new ArgumentNullException("commandText");      // If the provided connection is not open, we will open it      if (connection.State != ConnectionState.Open)      {        mustCloseConnection = true;        connection.Open();      }      else      {        mustCloseConnection = false;      }      // Associate the connection with the command      command.Connection = connection;      // Set the command text (stored procedure name or SQL statement)      command.CommandText = commandText;      // If we were provided a transaction, assign it      if (transaction != null)      {        if (transaction.Connection == null) throw new ArgumentException("The transaction was rollbacked or commited, please provide an open transaction.", "transaction");        command.Transaction = transaction;      }      // Set the command type      command.CommandType = commandType;      // Attach the command parameters if they are provided      if (commandParameters != null)      {        AttachParameters(command, commandParameters);      }      return;    }    #endregion private utility methods & constructors    #region ExecuteNonQuery    public static int ExecuteNonQuery(CommandType cmdType, string cmdText)    {      return ExecuteNonQuery(ConnectionString, cmdType, cmdText);    }    public static int ExecuteNonQuery(CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)    {      return ExecuteNonQuery(ConnectionString, cmdType, cmdText, commandParameters);    }    /// <summary>    /// Execute a SqlCommand (that returns no resultset and takes no parameters) against the database specified in     /// the connection string    /// </summary>    /// <remarks>    /// e.g.:     /// int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders");    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(string connectionString, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteNonQuery(connectionString, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns no resultset) against the database specified in the connection string     /// using the provided parameters    /// </summary>    /// <remarks>    /// e.g.:     /// int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString");      // Create & open a SqlConnection, and dispose of it after we are done      using (SqlConnection connection = new SqlConnection(connectionString))      {        connection.Open();        // Call the overload that takes a connection in place of the connection string        return ExecuteNonQuery(connection, commandType, commandText, commandParameters);      }    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns no resultset) against the database specified in     /// the connection string using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// int result = ExecuteNonQuery(connString, "PublishOrders", 24, 36);    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="spName">The name of the stored prcedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(string connectionString, string spName, params object[] parameterValues)    {      if (connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        // Pull the parameters for this stored procedure from the parameter cache (or discover them & populate the cache)        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connectionString, spName);        // Assign the provided values to these parameters based on parameter order        AssignParameterValues(commandParameters, parameterValues);        // Call the overload that takes an array of SqlParameters        return ExecuteNonQuery(connectionString, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteNonQuery(connectionString, CommandType.StoredProcedure, spName);      }    }    /// <summary>    /// Execute a SqlCommand (that returns no resultset and takes no parameters) against the provided SqlConnection.     /// </summary>    /// <remarks>    /// e.g.:     /// int result = ExecuteNonQuery(conn, CommandType.StoredProcedure, "PublishOrders");    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(SqlConnection connection, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteNonQuery(connection, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns no resultset) against the specified SqlConnection     /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     /// int result = ExecuteNonQuery(conn, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(SqlConnection connection, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (connection == null) throw new ArgumentNullException("connection");      // Create a command and prepare it for execution      SqlCommand cmd = new SqlCommand();      bool mustCloseConnection = false;      PrepareCommand(cmd, connection, (SqlTransaction)null, commandType, commandText, commandParameters, out mustCloseConnection);      // Finally, execute the command      int retval = cmd.ExecuteNonQuery();      // Detach the SqlParameters from the command object, so they can be used again      cmd.Parameters.Clear();      if (mustCloseConnection)        connection.Close();      return retval;    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns no resultset) against the specified SqlConnection     /// using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// int result = ExecuteNonQuery(conn, "PublishOrders", 24, 36);    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(SqlConnection connection, string spName, params object[] parameterValues)    {      if (connection == null) throw new ArgumentNullException("connection");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        // Pull the parameters for this stored procedure from the parameter cache (or discover them & populate the cache)        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connection, spName);        // Assign the provided values to these parameters based on parameter order        AssignParameterValues(commandParameters, parameterValues);        // Call the overload that takes an array of SqlParameters        return ExecuteNonQuery(connection, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteNonQuery(connection, CommandType.StoredProcedure, spName);      }    }    /// <summary>    /// Execute a SqlCommand (that returns no resultset and takes no parameters) against the provided SqlTransaction.     /// </summary>    /// <remarks>    /// e.g.:     /// int result = ExecuteNonQuery(trans, CommandType.StoredProcedure, "PublishOrders");    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(SqlTransaction transaction, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteNonQuery(transaction, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns no resultset) against the specified SqlTransaction    /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     /// int result = ExecuteNonQuery(trans, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(SqlTransaction transaction, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (transaction == null) throw new ArgumentNullException("transaction");      if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rollbacked or commited, please provide an open transaction.", "transaction");      // Create a command and prepare it for execution      SqlCommand cmd = new SqlCommand();      bool mustCloseConnection = false;      PrepareCommand(cmd, transaction.Connection, transaction, commandType, commandText, commandParameters, out mustCloseConnection);      // Finally, execute the command      int retval = cmd.ExecuteNonQuery();      // Detach the SqlParameters from the command object, so they can be used again      cmd.Parameters.Clear();      return retval;    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns no resultset) against the specified     /// SqlTransaction using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// int result = ExecuteNonQuery(conn, trans, "PublishOrders", 24, 36);    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>An int representing the number of rows affected by the command</returns>    public static int ExecuteNonQuery(SqlTransaction transaction, string spName, params object[] parameterValues)    {      if (transaction == null) throw new ArgumentNullException("transaction");      if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rollbacked or commited, please provide an open transaction.", "transaction");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        // Pull the parameters for this stored procedure from the parameter cache (or discover them & populate the cache)        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(transaction.Connection, spName);        // Assign the provided values to these parameters based on parameter order        AssignParameterValues(commandParameters, parameterValues);        // Call the overload that takes an array of SqlParameters        return ExecuteNonQuery(transaction, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteNonQuery(transaction, CommandType.StoredProcedure, spName);      }    }    #endregion ExecuteNonQuery    #region ExecuteDataset    public static DataSet ExecuteDataset(CommandType commandType, string commandText)    {      return ExecuteDataset(ConnectionString, commandType, commandText);    }    public static DataSet ExecuteDataset(CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      return ExecuteDataset(ConnectionString, commandType, commandText, commandParameters);    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset and takes no parameters) against the database specified in     /// the connection string.     /// </summary>    /// <remarks>    /// e.g.:     /// DataSet ds = ExecuteDataset(connString, CommandType.StoredProcedure, "GetOrders");    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteDataset(connectionString, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset) against the database specified in the connection string     /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     /// DataSet ds = ExecuteDataset(connString, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString");      // Create & open a SqlConnection, and dispose of it after we are done      using (SqlConnection connection = new SqlConnection(connectionString))      {        connection.Open();        // Call the overload that takes a connection in place of the connection string        return ExecuteDataset(connection, commandType, commandText, commandParameters);      }    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns a resultset) against the database specified in     /// the connection string using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// DataSet ds = ExecuteDataset(connString, "GetOrders", 24, 36);    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(string connectionString, string spName, params object[] parameterValues)    {      if (connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        // Pull the parameters for this stored procedure from the parameter cache (or discover them & populate the cache)        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connectionString, spName);        // Assign the provided values to these parameters based on parameter order        AssignParameterValues(commandParameters, parameterValues);        // Call the overload that takes an array of SqlParameters        return ExecuteDataset(connectionString, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteDataset(connectionString, CommandType.StoredProcedure, spName);      }    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset and takes no parameters) against the provided SqlConnection.     /// </summary>    /// <remarks>    /// e.g.:     /// DataSet ds = ExecuteDataset(conn, CommandType.StoredProcedure, "GetOrders");    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(SqlConnection connection, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteDataset(connection, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset) against the specified SqlConnection     /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     /// DataSet ds = ExecuteDataset(conn, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(SqlConnection connection, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (connection == null) throw new ArgumentNullException("connection");      // Create a command and prepare it for execution      SqlCommand cmd = new SqlCommand();      bool mustCloseConnection = false;      PrepareCommand(cmd, connection, (SqlTransaction)null, commandType, commandText, commandParameters, out mustCloseConnection);      // Create the DataAdapter & DataSet      using (SqlDataAdapter da = new SqlDataAdapter(cmd))      {        DataSet ds = new DataSet();        // Fill the DataSet using default values for DataTable names, etc        da.Fill(ds);        // Detach the SqlParameters from the command object, so they can be used again        cmd.Parameters.Clear();        if (mustCloseConnection)          connection.Close();        // Return the dataset        return ds;      }    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns a resultset) against the specified SqlConnection     /// using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// DataSet ds = ExecuteDataset(conn, "GetOrders", 24, 36);    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(SqlConnection connection, string spName, params object[] parameterValues)    {      if (connection == null) throw new ArgumentNullException("connection");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        // Pull the parameters for this stored procedure from the parameter cache (or discover them & populate the cache)        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connection, spName);        // Assign the provided values to these parameters based on parameter order        AssignParameterValues(commandParameters, parameterValues);        // Call the overload that takes an array of SqlParameters        return ExecuteDataset(connection, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteDataset(connection, CommandType.StoredProcedure, spName);      }    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset and takes no parameters) against the provided SqlTransaction.     /// </summary>    /// <remarks>    /// e.g.:     /// DataSet ds = ExecuteDataset(trans, CommandType.StoredProcedure, "GetOrders");    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(SqlTransaction transaction, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteDataset(transaction, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset) against the specified SqlTransaction    /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     /// DataSet ds = ExecuteDataset(trans, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(SqlTransaction transaction, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (transaction == null) throw new ArgumentNullException("transaction");      if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rollbacked or commited, please provide an open transaction.", "transaction");      // Create a command and prepare it for execution      SqlCommand cmd = new SqlCommand();      bool mustCloseConnection = false;      PrepareCommand(cmd, transaction.Connection, transaction, commandType, commandText, commandParameters, out mustCloseConnection);      // Create the DataAdapter & DataSet      using (SqlDataAdapter da = new SqlDataAdapter(cmd))      {        DataSet ds = new DataSet();        // Fill the DataSet using default values for DataTable names, etc        da.Fill(ds);        // Detach the SqlParameters from the command object, so they can be used again        cmd.Parameters.Clear();        // Return the dataset        return ds;      }    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns a resultset) against the specified     /// SqlTransaction using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// DataSet ds = ExecuteDataset(trans, "GetOrders", 24, 36);    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>A dataset containing the resultset generated by the command</returns>    public static DataSet ExecuteDataset(SqlTransaction transaction, string spName, params object[] parameterValues)    {      if (transaction == null) throw new ArgumentNullException("transaction");      if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rollbacked or commited, please provide an open transaction.", "transaction");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        // Pull the parameters for this stored procedure from the parameter cache (or discover them & populate the cache)        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(transaction.Connection, spName);        // Assign the provided values to these parameters based on parameter order        AssignParameterValues(commandParameters, parameterValues);        // Call the overload that takes an array of SqlParameters        return ExecuteDataset(transaction, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteDataset(transaction, CommandType.StoredProcedure, spName);      }    }    #endregion ExecuteDataset    #region ExecuteReader    /// <summary>    /// This enum is used to indicate whether the connection was provided by the caller, or created by SqlHelper, so that    /// we can set the appropriate CommandBehavior when calling ExecuteReader()    /// </summary>    private enum SqlConnectionOwnership    {      /// <summary>Connection is owned and managed by SqlHelper</summary>      Internal,      /// <summary>Connection is owned and managed by the caller</summary>      External    }    public static SqlDataReader ExecuteReader(CommandType cmdType, string cmdText)    {      return ExecuteReader(ConnectionString, cmdType, cmdText);    }    public static SqlDataReader ExecuteReader(CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)    {      return ExecuteReader(ConnectionString, cmdType, cmdText, commandParameters);    }    /// <summary>    /// Create and prepare a SqlCommand, and call ExecuteReader with the appropriate CommandBehavior.    /// </summary>    /// <remarks>    /// If we created and opened the connection, we want the connection to be closed when the DataReader is closed.    ///     /// If the caller provided the connection, we want to leave it to them to manage.    /// </remarks>    /// <param name="connection">A valid SqlConnection, on which to execute this command</param>    /// <param name="transaction">A valid SqlTransaction, or 'null'</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParameters to be associated with the command or 'null' if no parameters are required</param>    /// <param name="connectionOwnership">Indicates whether the connection parameter was provided by the caller, or created by SqlHelper</param>    /// <returns>SqlDataReader containing the results of the command</returns>    private static SqlDataReader ExecuteReader(SqlConnection connection, SqlTransaction transaction, CommandType commandType, string commandText, SqlParameter[] commandParameters, SqlConnectionOwnership connectionOwnership)    {      if (connection == null) throw new ArgumentNullException("connection");      bool mustCloseConnection = false;      // Create a command and prepare it for execution      SqlCommand cmd = new SqlCommand();      try      {        PrepareCommand(cmd, connection, transaction, commandType, commandText, commandParameters, out mustCloseConnection);        // Create a reader        SqlDataReader dataReader;        // Call ExecuteReader with the appropriate CommandBehavior        if (connectionOwnership == SqlConnectionOwnership.External)        {          dataReader = cmd.ExecuteReader();        }        else        {          dataReader = cmd.ExecuteReader(CommandBehavior.CloseConnection);        }        // Detach the SqlParameters from the command object, so they can be used again.        // HACK: There is a problem here, the output parameter values are fletched         // when the reader is closed, so if the parameters are detached from the command        // then the SqlReader cant set its values.         // When this happen, the parameters cant be used again in other command.        bool canClear = true;        foreach (SqlParameter commandParameter in cmd.Parameters)        {          if (commandParameter.Direction != ParameterDirection.Input)            canClear = false;        }        if (canClear)        {          cmd.Parameters.Clear();        }        return dataReader;      }      catch      {        if (mustCloseConnection)          connection.Close();        throw;      }    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset and takes no parameters) against the database specified in     /// the connection string.     /// </summary>    /// <remarks>    /// e.g.:     /// SqlDataReader dr = ExecuteReader(connString, CommandType.StoredProcedure, "GetOrders");    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(string connectionString, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteReader(connectionString, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset) against the database specified in the connection string     /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     /// SqlDataReader dr = ExecuteReader(connString, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString");      SqlConnection connection = null;      try      {        connection = new SqlConnection(connectionString);        connection.Open();        // Call the private overload that takes an internally owned connection in place of the connection string        return ExecuteReader(connection, null, commandType, commandText, commandParameters, SqlConnectionOwnership.Internal);      }      catch      {        // If we fail to return the SqlDatReader, we need to close the connection ourselves        if (connection != null) connection.Close();        throw;      }    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns a resultset) against the database specified in     /// the connection string using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// SqlDataReader dr = ExecuteReader(connString, "GetOrders", 24, 36);    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(string connectionString, string spName, params object[] parameterValues)    {      if (connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connectionString, spName);        AssignParameterValues(commandParameters, parameterValues);        return ExecuteReader(connectionString, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteReader(connectionString, CommandType.StoredProcedure, spName);      }    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset and takes no parameters) against the provided SqlConnection.     /// </summary>    /// <remarks>    /// e.g.:     /// SqlDataReader dr = ExecuteReader(conn, CommandType.StoredProcedure, "GetOrders");    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(SqlConnection connection, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteReader(connection, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset) against the specified SqlConnection     /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     /// SqlDataReader dr = ExecuteReader(conn, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(SqlConnection connection, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      // Pass through the call to the private overload using a null transaction value and an externally owned connection      return ExecuteReader(connection, (SqlTransaction)null, commandType, commandText, commandParameters, SqlConnectionOwnership.External);    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns a resultset) against the specified SqlConnection     /// using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// SqlDataReader dr = ExecuteReader(conn, "GetOrders", 24, 36);    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(SqlConnection connection, string spName, params object[] parameterValues)    {      if (connection == null) throw new ArgumentNullException("connection");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connection, spName);        AssignParameterValues(commandParameters, parameterValues);        return ExecuteReader(connection, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteReader(connection, CommandType.StoredProcedure, spName);      }    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset and takes no parameters) against the provided SqlTransaction.     /// </summary>    /// <remarks>    /// e.g.:     /// SqlDataReader dr = ExecuteReader(trans, CommandType.StoredProcedure, "GetOrders");    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(SqlTransaction transaction, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteReader(transaction, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns a resultset) against the specified SqlTransaction    /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     ///  SqlDataReader dr = ExecuteReader(trans, CommandType.StoredProcedure, "GetOrders", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(SqlTransaction transaction, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (transaction == null) throw new ArgumentNullException("transaction");      if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rollbacked or commited, please provide an open transaction.", "transaction");      // Pass through to private overload, indicating that the connection is owned by the caller      return ExecuteReader(transaction.Connection, transaction, commandType, commandText, commandParameters, SqlConnectionOwnership.External);    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns a resultset) against the specified    /// SqlTransaction using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// SqlDataReader dr = ExecuteReader(trans, "GetOrders", 24, 36);    /// </remarks>    /// <param name="transaction">A valid SqlTransaction</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>A SqlDataReader containing the resultset generated by the command</returns>    public static SqlDataReader ExecuteReader(SqlTransaction transaction, string spName, params object[] parameterValues)    {      if (transaction == null) throw new ArgumentNullException("transaction");      if (transaction != null && transaction.Connection == null) throw new ArgumentException("The transaction was rollbacked or commited, please provide an open transaction.", "transaction");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(transaction.Connection, spName);        AssignParameterValues(commandParameters, parameterValues);        return ExecuteReader(transaction, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteReader(transaction, CommandType.StoredProcedure, spName);      }    }    #endregion ExecuteReader    #region ExecuteScalar    public static object ExecuteScalar(CommandType cmdType, string cmdText)    {      return ExecuteScalar(ConnectionString, cmdType, cmdText);    }    public static object ExecuteScalar(CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)    {      return ExecuteScalar(ConnectionString, cmdType, cmdText, commandParameters);    }    /// <summary>    /// Execute a SqlCommand (that returns a 1x1 resultset and takes no parameters) against the database specified in     /// the connection string.     /// </summary>    /// <remarks>    /// e.g.:     /// int orderCount = (int)ExecuteScalar(connString, CommandType.StoredProcedure, "GetOrderCount");    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>An object containing the value in the 1x1 resultset generated by the command</returns>    public static object ExecuteScalar(string connectionString, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteScalar(connectionString, commandType, commandText, (SqlParameter[])null);    }    /// <summary>    /// Execute a SqlCommand (that returns a 1x1 resultset) against the database specified in the connection string     /// using the provided parameters.    /// </summary>    /// <remarks>    /// e.g.:     /// int orderCount = (int)ExecuteScalar(connString, CommandType.StoredProcedure, "GetOrderCount", new SqlParameter("@prodid", 24));    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <param name="commandParameters">An array of SqlParamters used to execute the command</param>    /// <returns>An object containing the value in the 1x1 resultset generated by the command</returns>    public static object ExecuteScalar(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)    {      if (connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString");      // Create & open a SqlConnection, and dispose of it after we are done      using (SqlConnection connection = new SqlConnection(connectionString))      {        connection.Open();        // Call the overload that takes a connection in place of the connection string        return ExecuteScalar(connection, commandType, commandText, commandParameters);      }    }    /// <summary>    /// Execute a stored procedure via a SqlCommand (that returns a 1x1 resultset) against the database specified in     /// the connection string using the provided parameter values. This method will query the database to discover the parameters for the     /// stored procedure (the first time each stored procedure is called), and assign the values based on parameter order.    /// </summary>    /// <remarks>    /// This method provides no access to output parameters or the stored procedure's return value parameter.    ///     /// e.g.:     /// int orderCount = (int)ExecuteScalar(connString, "GetOrderCount", 24, 36);    /// </remarks>    /// <param name="connectionString">A valid connection string for a SqlConnection</param>    /// <param name="spName">The name of the stored procedure</param>    /// <param name="parameterValues">An array of objects to be assigned as the input values of the stored procedure</param>    /// <returns>An object containing the value in the 1x1 resultset generated by the command</returns>    public static object ExecuteScalar(string connectionString, string spName, params object[] parameterValues)    {      if (connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString");      if (spName == null || spName.Length == 0) throw new ArgumentNullException("spName");      // If we receive parameter values, we need to figure out where they go      if ((parameterValues != null) && (parameterValues.Length > 0))      {        // Pull the parameters for this stored procedure from the parameter cache (or discover them & populate the cache)        SqlParameter[] commandParameters = SqlHelperParameterCache.GetSpParameterSet(connectionString, spName);        // Assign the provided values to these parameters based on parameter order        AssignParameterValues(commandParameters, parameterValues);        // Call the overload that takes an array of SqlParameters        return ExecuteScalar(connectionString, CommandType.StoredProcedure, spName, commandParameters);      }      else      {        // Otherwise we can just call the SP without params        return ExecuteScalar(connectionString, CommandType.StoredProcedure, spName);      }    }    /// <summary>    /// Execute a SqlCommand (that returns a 1x1 resultset and takes no parameters) against the provided SqlConnection.     /// </summary>    /// <remarks>    /// e.g.:     /// int orderCount = (int)ExecuteScalar(conn, CommandType.StoredProcedure, "GetOrderCount");    /// </remarks>    /// <param name="connection">A valid SqlConnection</param>    /// <param name="commandType">The CommandType (stored procedure, text, etc.)</param>    /// <param name="commandText">The stored procedure name or T-SQL command</param>    /// <returns>An object containing the value in the 1x1 resultset generated by the command</returns>    public static object ExecuteScalar(SqlConnection connection, CommandType commandType, string commandText)    {      // Pass through the call providing null for the set of SqlParameters      return ExecuteScala            


  • 上一条:
    SQl Function 创建函数实例介绍
    下一条:
    用连接池提高Servlet访问数据库的效率(1)
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 分库分表的目的、优缺点及具体实现方式介绍(0个评论)
    • DevDB - 在 VS 代码中直接访问数据库(0个评论)
    • 在ubuntu系统中实现mysql数据存储目录迁移流程步骤(0个评论)
    • 在mysql中使用存储过程批量新增测试数据流程步骤(0个评论)
    • php+mysql数据库批量根据条件快速更新、连表更新sql实现(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-06
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-01
    • 2018-05
    • 2018-10
    • 2018-11
    • 2020-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2021-02
    • 2021-04
    • 2021-07
    • 2021-08
    • 2021-11
    • 2021-12
    • 2022-02
    • 2022-03
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-07
    • 2023-08
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客