数据访问基础类

ContractedBlock.gif ExpandedBlockStart.gif Code
 1ExpandedBlockStart.gifContractedBlock.gif        /**//// <summary>
 2        /// 执行存储过程
 3        /// </summary>
 4        /// <param name="storedProcName">存储过程名</param>
 5        /// <param name="parameters">存储过程参数</param>
 6        /// <param name="tableName">DataSet结果中的表名</param>
 7        /// <returns>DataSet</returns>

 8        public static DataSet RunProcedure(string storedProcName, IDataParameter[] parameters, string tableName)
 9ExpandedBlockStart.gifContractedBlock.gif        {
10            using (SqlConnection connection = new SqlConnection(connectionString))
11ExpandedSubBlockStart.gifContractedSubBlock.gif            {
12                DataSet dataSet = new DataSet();
13                connection.Open();
14                SqlDataAdapter sqlDA = new SqlDataAdapter();
15                sqlDA.SelectCommand = BuildQueryCommand(connection, storedProcName, parameters);
16                sqlDA.Fill(dataSet, tableName);
17                connection.Close();
18                return dataSet;
19            }

20        }
ContractedBlock.gif ExpandedBlockStart.gif Code
 1ExpandedBlockStart.gifContractedBlock.gif        /**//// <summary>
 2        /// 构建 SqlCommand 对象(用来返回一个结果集,而不是一个整数值)
 3        /// </summary>
 4        /// <param name="connection">数据库连接</param>
 5        /// <param name="storedProcName">存储过程名</param>
 6        /// <param name="parameters">存储过程参数</param>
 7        /// <returns>SqlCommand</returns>

 8        private static SqlCommand BuildQueryCommand(SqlConnection connection, string storedProcName, IDataParameter[] parameters)
 9ExpandedBlockStart.gifContractedBlock.gif        {
10            SqlCommand command = new SqlCommand(storedProcName, connection);
11            command.CommandType = CommandType.StoredProcedure;
12            foreach (SqlParameter parameter in parameters)
13ExpandedSubBlockStart.gifContractedSubBlock.gif            {
14                if (parameter != null)
15ExpandedSubBlockStart.gifContractedSubBlock.gif                {
16                    // 检查未分配值的输出参数,将其分配以DBNull.Value.
17                    if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&
18                        (parameter.Value == null))
19ExpandedSubBlockStart.gifContractedSubBlock.gif                    {
20                        parameter.Value = DBNull.Value;
21                    }

22                    command.Parameters.Add(parameter);
23                }

24            }

25
26            return command;
27        }

转载于:https://www.cnblogs.com/ning-ning/archive/2008/11/06/1328050.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值