#region ExecuteNonQuery(如果是增,删,修)
/// <summary>
/// 执行sql命令
/// </summary>
/// <param name="connectionString">连接字符串</param>
/// <param name="commandType">命令类型</param>
/// <param name="commandText">sql语句/参数化sql语句/存储过程名</param>
/// <param name="commandParameters">参数</param>
/// <returns>受影响的行数</returns>
public static int ExecuteNonQuery(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
{ SqlCommand cmd = new SqlCommand(); using (SqlConnection conn = new SqlConnection(connectionString))
{
PrepareCommand(cmd, commandType, conn, commandText, commandParameters);
int val = cmd.ExecuteNonQuery(); return val;
}
} /// <summary>
/// 执行Sql Server存储过程
/// 注意:不能执行有out 参数的存储过程
/// </summary>
/// <param name="connectionString">连接字符串</param>
/// <param name="spName">存储过程名</param>
/// <param name="parameterValues">对象参数</param>
/// <returns>受影响的行数</returns>
public static int ExecuteNonQuery(string connectionString, string spName, params object[] parameterValues)
{ using (SqlConnection conn = new SqlConnection(connectionString))
{
SqlCommand cmd = new SqlCommand(); PrepareCommand(cmd, conn, spName, parameterValues);
int val = cmd.ExecuteNonQuery(); return val;
}
}
#endregion #region ExecuteReader(如果只是读数据)
/// <summary>
/// 执行sql命令
/// </summary>
/// <param name="connectionString">连接字符串</param>
/// <param name="commandType">命令类型</param>
/// <param name="commandText">sql语句/参数化sql语句/存储过程名</param>
/// <param name="commandParameters">参数</param>
/// <returns>SqlDataReader 对象</returns>
public static SqlDataReader ExecuteReader(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
{ SqlConnection conn = new SqlConnection(connectionString);
try
{
SqlCommand cmd = new SqlCommand();
PrepareCommand(cmd, commandType, conn, commandText, commandParameters);
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection); return rdr;
}
catch
{
conn.Close();
throw;
}
} /// <summary>
/// 执行Sql Server存储过程
/// 注意:不能执行有out 参数的存储过程
/// </summary>
/// <param name="connectionString">连接字符串</param>
/// <param name="spName">存储过程名</param>
/// <param name="parameterValues">对象参数</param>
/// <returns>受影响的行数</returns>
public static SqlDataReader ExecuteReader(string connectionString, string spName, params object[] parameterValues)
{
SqlConnection conn = new SqlConnection(connectionString);
try
{
SqlCommand cmd = new SqlCommand(); PrepareCommand(cmd, conn, spName, parameterValues);
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection); return rdr;
}
catch
{
conn.Close();
throw;
} }
#endregion #region ExecuteDataset(如果查询一个数据集) /// <summary>
/// 执行Sql Server存储过程
/// 注意:不能执行有out 参数的存储过程
/// </summary>
/// <param name="connectionString">连接字符串</param>
/// <param name="spName">存储过程名</param>
/// <param name="parameterValues">对象参数</param>
/// <returns>DataSet对象</returns>
public static DataSet ExecuteDataset(string connectionString, string spName, params object[] parameterValues)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
SqlCommand cmd = new SqlCommand(); PrepareCommand(cmd, conn, spName, parameterValues); using (SqlDataAdapter da = new SqlDataAdapter(cmd))
{
DataSet ds = new DataSet(); da.Fill(ds); return ds;
}
}
} /// <summary>
/// 执行Sql 命令
/// </summary>
/// <param name="connectionString">连接字符串</param>
/// <param name="commandType">命令类型</param>
/// <param name="commandText">sql语句/参数化sql语句/存储过程名</param>
/// <param name="commandParameters">参数</param>
/// <returns>DataSet 对象</returns>
public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{ SqlCommand cmd = new SqlCommand(); PrepareCommand(cmd, commandType, conn, commandText, commandParameters);
using (SqlDataAdapter da = new SqlDataAdapter(cmd))
{
DataSet ds = new DataSet(); da.Fill(ds); return ds;
}
}
} #endregion #region ExecuteScalar (如果你只查询一个值)
/// <summary>
/// 执行Sql 命令
/// </summary>
/// <param name="connectionString">连接字符串</param>
/// <param name="commandType">命令类型</param>
/// <param name="commandText">sql语句/参数化sql语句/存储过程名</param>
/// <param name="commandParameters">参数</param>
/// <returns>执行结果对象</returns>
public static object ExecuteScalar(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
{
SqlCommand cmd = new SqlCommand(); using (SqlConnection conn = new SqlConnection(connectionString))
{
PrepareCommand(cmd, commandType, conn, commandText, commandParameters);
object val = cmd.ExecuteScalar(); return val;
}
} /// <summary>
/// 执行Sql Server存储过程
/// 注意:不能执行有out 参数的存储过程
/// </summary>
/// <param name="connectionString">连接字符串</param>
/// <param name="spName">存储过程名</param>
/// <param name="parameterValues">对象参数</param>
/// <returns>执行结果对象</returns>
public static object ExecuteScalar(string connectionString, string spName, params object[] parameterValues)
{
SqlCommand cmd = new SqlCommand(); using (SqlConnection conn = new SqlConnection(connectionString))
{
PrepareCommand(cmd, conn, spName, parameterValues);
object val = cmd.ExecuteScalar(); return val;
}
} #endregion #region Private Method
/// <summary>
/// 设置一个等待执行的SqlCommand对象
/// </summary>
/// <param name="cmd">SqlCommand 对象,不允许空对象</param>
/// <param name="conn">SqlConnection 对象,不允许空对象</param>
/// <param name="commandText">Sql 语句</param>
/// <param name="cmdParms">SqlParameters 对象,允许为空对象</param>
private static void PrepareCommand(SqlCommand cmd, CommandType commandType, SqlConnection conn, string commandText, SqlParameter[] cmdParms)
{
//打开连接
if (conn.State != ConnectionState.Open)
conn.Open(); //设置SqlCommand对象
cmd.Connection = conn;
cmd.CommandText = commandText;
cmd.CommandType = commandType; if (cmdParms != null)
{
foreach (SqlParameter parm in cmdParms)
cmd.Parameters.Add(parm);
}
} /// <summary>
/// 设置一个等待执行存储过程的SqlCommand对象
/// </summary>
/// <param name="cmd">SqlCommand 对象,不允许空对象</param>
/// <param name="conn">SqlConnection 对象,不允许空对象</param>
/// <param name="spName">Sql 语句</param>
/// <param name="parameterValues">不定个数的存储过程参数,允许为空</param>
private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, string spName, params object[] parameterValues)
{
//打开连接
if (conn.State != ConnectionState.Open)
conn.Open(); //设置SqlCommand对象
cmd.Connection = conn;
cmd.CommandText = spName;
cmd.CommandType = CommandType.StoredProcedure; //获取存储过程的参数
SqlCommandBuilder.DeriveParameters(cmd); //移除Return_Value 参数
cmd.Parameters.RemoveAt(); //设置参数值
if (parameterValues != null)
{
for (int i = ; i < cmd.Parameters.Count; i++)
{
cmd.Parameters[i].Value = parameterValues[i]; }
}
}
#endregion

#region ExecuteNonQuery(如果是增,删,修)      /// <summary>      /// 执行sql命令      /// </summary>      /// <param name="connectionString">连接字符串</param>      /// <param name="commandType">命令类型</param>      /// <param name="commandText">sql语句/参数化sql语句/存储过程名</param>      /// <param name="commandParameters">参数</param>      /// <returns>受影响的行数</returns>      public static int ExecuteNonQuery(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)      {
          SqlCommand cmd = new SqlCommand();
          using (SqlConnection conn = new SqlConnection(connectionString))          {              PrepareCommand(cmd, commandType, conn, commandText, commandParameters);              int val = cmd.ExecuteNonQuery();
              return val;          }      }
      /// <summary>      /// 执行Sql Server存储过程      /// 注意:不能执行有out 参数的存储过程      /// </summary>      /// <param name="connectionString">连接字符串</param>      /// <param name="spName">存储过程名</param>      /// <param name="parameterValues">对象参数</param>      /// <returns>受影响的行数</returns>      public static int ExecuteNonQuery(string connectionString, string spName, params object[] parameterValues)      {
          using (SqlConnection conn = new SqlConnection(connectionString))          {              SqlCommand cmd = new SqlCommand();
              PrepareCommand(cmd, conn, spName, parameterValues);              int val = cmd.ExecuteNonQuery();
              return val;          }      }      #endregion
      #region ExecuteReader(如果只是读数据)      /// <summary>      ///  执行sql命令      /// </summary>      /// <param name="connectionString">连接字符串</param>      /// <param name="commandType">命令类型</param>      /// <param name="commandText">sql语句/参数化sql语句/存储过程名</param>      /// <param name="commandParameters">参数</param>      /// <returns>SqlDataReader 对象</returns>      public static SqlDataReader ExecuteReader(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)      {
          SqlConnection conn = new SqlConnection(connectionString);          try          {              SqlCommand cmd = new SqlCommand();              PrepareCommand(cmd, commandType, conn, commandText, commandParameters);              SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
              return rdr;          }          catch          {              conn.Close();              throw;          }      }
      /// <summary>      /// 执行Sql Server存储过程      /// 注意:不能执行有out 参数的存储过程      /// </summary>      /// <param name="connectionString">连接字符串</param>      /// <param name="spName">存储过程名</param>      /// <param name="parameterValues">对象参数</param>      /// <returns>受影响的行数</returns>      public static SqlDataReader ExecuteReader(string connectionString, string spName, params object[] parameterValues)      {          SqlConnection conn = new SqlConnection(connectionString);          try          {              SqlCommand cmd = new SqlCommand();
              PrepareCommand(cmd, conn, spName, parameterValues);              SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
              return rdr;          }          catch          {              conn.Close();              throw;          }
      }      #endregion
      #region ExecuteDataset(如果查询一个数据集)
      /// <summary>      /// 执行Sql Server存储过程      /// 注意:不能执行有out 参数的存储过程      /// </summary>      /// <param name="connectionString">连接字符串</param>      /// <param name="spName">存储过程名</param>      /// <param name="parameterValues">对象参数</param>      /// <returns>DataSet对象</returns>      public static DataSet ExecuteDataset(string connectionString, string spName, params object[] parameterValues)      {          using (SqlConnection conn = new SqlConnection(connectionString))          {              SqlCommand cmd = new SqlCommand();
              PrepareCommand(cmd, conn, spName, parameterValues);
              using (SqlDataAdapter da = new SqlDataAdapter(cmd))              {                  DataSet ds = new DataSet();
                  da.Fill(ds);
                  return ds;              }          }      }

/// <summary>      /// 执行Sql 命令      /// </summary>      /// <param name="connectionString">连接字符串</param>      /// <param name="commandType">命令类型</param>      /// <param name="commandText">sql语句/参数化sql语句/存储过程名</param>      /// <param name="commandParameters">参数</param>      /// <returns>DataSet 对象</returns>      public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)      {          using (SqlConnection conn = new SqlConnection(connectionString))          {
              SqlCommand cmd = new SqlCommand();
              PrepareCommand(cmd, commandType, conn, commandText, commandParameters);              using (SqlDataAdapter da = new SqlDataAdapter(cmd))              {                  DataSet ds = new DataSet();
                  da.Fill(ds);
                  return ds;              }          }      }
      #endregion
      #region ExecuteScalar (如果你只查询一个值)      /// <summary>      /// 执行Sql 命令      /// </summary>      /// <param name="connectionString">连接字符串</param>      /// <param name="commandType">命令类型</param>      /// <param name="commandText">sql语句/参数化sql语句/存储过程名</param>      /// <param name="commandParameters">参数</param>      /// <returns>执行结果对象</returns>      public static object ExecuteScalar(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)      {          SqlCommand cmd = new SqlCommand();
          using (SqlConnection conn = new SqlConnection(connectionString))          {              PrepareCommand(cmd, commandType, conn, commandText, commandParameters);              object val = cmd.ExecuteScalar();
              return val;          }      }
      /// <summary>      /// 执行Sql Server存储过程      /// 注意:不能执行有out 参数的存储过程      /// </summary>      /// <param name="connectionString">连接字符串</param>      /// <param name="spName">存储过程名</param>      /// <param name="parameterValues">对象参数</param>      /// <returns>执行结果对象</returns>      public static object ExecuteScalar(string connectionString, string spName, params object[] parameterValues)      {          SqlCommand cmd = new SqlCommand();
          using (SqlConnection conn = new SqlConnection(connectionString))          {              PrepareCommand(cmd, conn, spName, parameterValues);              object val = cmd.ExecuteScalar();
              return val;          }      }

#endregion
      #region Private Method      /// <summary>      /// 设置一个等待执行的SqlCommand对象      /// </summary>      /// <param name="cmd">SqlCommand 对象,不允许空对象</param>      /// <param name="conn">SqlConnection 对象,不允许空对象</param>      /// <param name="commandText">Sql 语句</param>      /// <param name="cmdParms">SqlParameters  对象,允许为空对象</param>      private static void PrepareCommand(SqlCommand cmd, CommandType commandType, SqlConnection conn, string commandText, SqlParameter[] cmdParms)      {          //打开连接          if (conn.State != ConnectionState.Open)              conn.Open();
          //设置SqlCommand对象          cmd.Connection = conn;          cmd.CommandText = commandText;          cmd.CommandType = commandType;
          if (cmdParms != null)          {              foreach (SqlParameter parm in cmdParms)                  cmd.Parameters.Add(parm);          }      }
      /// <summary>      /// 设置一个等待执行存储过程的SqlCommand对象      /// </summary>      /// <param name="cmd">SqlCommand 对象,不允许空对象</param>      /// <param name="conn">SqlConnection 对象,不允许空对象</param>      /// <param name="spName">Sql 语句</param>      /// <param name="parameterValues">不定个数的存储过程参数,允许为空</param>      private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, string spName, params object[] parameterValues)      {          //打开连接          if (conn.State != ConnectionState.Open)              conn.Open();
          //设置SqlCommand对象          cmd.Connection = conn;          cmd.CommandText = spName;          cmd.CommandType = CommandType.StoredProcedure;
          //获取存储过程的参数          SqlCommandBuilder.DeriveParameters(cmd);
          //移除Return_Value 参数          cmd.Parameters.RemoveAt(0);
          //设置参数值          if (parameterValues != null)          {              for (int i = 0; i < cmd.Parameters.Count; i++)              {                  cmd.Parameters[i].Value = parameterValues[i];
              }          }      }      #endregion

CS通用项目系统搭建——三层架构第二天 (补一篇完整的SqlHelper)的更多相关文章

  1. CS通用项目系统搭建——三层架构第二天

    一.编写配置文件 首先找到编写配置文件的位置.winform会在app.config.webform写在web.config中. <?xml version="1.0" en ...

  2. CS通用项目系统搭建——三层架构第一天

    CS通用项目:使用三层架构进行搭建 三层架构: 表现层(UI(User Interface)):展示给用户的层面,包含窗体控件数据等信息. 业务逻辑层(BLL(Business Logic Layer ...

  3. 关于ASP.NET或VS2005 搭建三层架构的理解

    最近想学习ASP.NET建网站,关于ASP.NET或VS2005 搭建三层架构的理解,网上摘录了一些资料,对于第(2)点的讲解让我理解印象深刻,如下: (1)为何使用N层架构? 因为每一层都可以在仅仅 ...

  4. MVC项目实践,在三层架构下实现SportsStore-02,DbSession层、BLL层

    SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...

  5. MVC项目实践,在三层架构下实现SportsStore-01,EF Code First建模、DAL层等

    SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...

  6. MVC项目实践,在三层架构下实现SportsStore,从类图看三层架构

    在"MVC项目实践,在三层架构下实现SportsStore-02,DbSession层.BLL层"一文的评论中,博友浪花一朵朵建议用类图来理解本项目的三层架构.于是就有了本篇: I ...

  7. MVC项目实践,在三层架构下实现SportsStore-03,Ninject控制器工厂等

    SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...

  8. MVC项目实践,在三层架构下实现SportsStore-04,实现分页

    SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...

  9. MVC项目实践,在三层架构下实现SportsStore-05,实现导航

    SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...

随机推荐

  1. 【配置阿里云 I】申请配置阿里云服务器,并部署IIS和开发环境,项目上线经验

    https://blog.csdn.net/vapaad1/article/details/78769520 最近一年在实验室做web后端开发,涉及到一些和服务器搭建及部署上线项目的相关经验,写个帖子 ...

  2. 申请Let's Encrypt永久免费SSL证书

    Let's Encrypt简介 Let's Encrypt作为一个公共且免费SSL的项目逐渐被广大用户传播和使用,是由Mozilla.Cisco.Akamai.IdenTrust.EFF等组织人员发起 ...

  3. APS技术中的多目标规划问题

    在进行APS(高级计划与排程)系统开发时,绝大多数情况下是需要考虑多目标的.但面对多目标问题进行规划求解时,我们往往极容易因处理方法不当,而影响输出结果,令结果与用户期望产生较大差别.事实上很多时候用 ...

  4. ARC085F NRE

    看了题解. 题目大意 你有一个长度为 \(N\) 的全为 \(0\) 的序列 \(A\),给你一个长度同样为 \(N\) 的 \(0/1\) 序列 \(B\),允许你对把 \(A\) 的一些区间中的数 ...

  5. 7.2.5 多层嵌套的if语句

    7.2.5 多层嵌套的if语句 在编写程序的代码之前要先规划好.首先,要总体设计一下程序. 为方便起见,程序应该使用一个连续的循环让用户能连续输入待测试的 数.这样,测试一个新的数字不必每次都要重新运 ...

  6. win10家庭版,双击bat文件无法运行(double click bat file does not execute)

    win10家庭版,双击bat文件无法运行,弹出文件打开方式选择框. 在网上搜索处理办法,试了以下方法1-5都没有成功,用方法6规避. 方法1:打开一个驱动器,点“工具-文件夹选项→文件类型→新建→扩展 ...

  7. axublogcms1.1.0 Getshell

    axublogcms1.1.0 Getshell 代码执行漏洞 现在最新版是1.1.0   今天重新审计了下 axublogcms1.0.6 ,发现一处计较鸡肋的漏洞,因为并不是只有1.0.6版本存在 ...

  8. 用antd和webview打造一款大数据客户端程序

    要想提高工作效率,必须得有好的工具.大数据有很多组件,但是邪了门儿的就是,竟然没有一个好用的客户端程序. 没办法,我只好用antd+webview自己做了一款跨平台的桌面应用. 先看下效果. 这是gi ...

  9. TMS320F28335系列芯片地址映射表

    本表非官方资料,纯属个人学习笔记,欢迎补充 本表非官方资料,纯属个人学习笔记,欢迎补充 本表非官方资料,纯属个人学习笔记,欢迎补充 开始地址 长度 名称 物理器件 程序 数据 只读 Protected ...

  10. java+Selenium+TestNg搭建自动化测试架构(1)实现代码和数据的分离

    1.主要介绍介绍Java+Selenium+POM的自动化测试框架的搭建,第一个首先实现代码和账号URL等信息的分离.第二点支持跨浏览器,通过读取配置文件的方式实现. 1)将账号URL等信息添加在pr ...