C#存储过程调用通用类

  1. // ==============================
  2. // Author:  ZhiQiao
  3. // Date:    2008/09/16
  4. // File:    StoreProcedure.cs
  5. // ==============================
  6. namespace Kenwood.Product.DataAccessHelper
  7. {
  8.     using System;
  9.     using System.Data;
  10.     using System.Data.SqlClient;
  11.     
  12.     /**//// <summary>
  13.     /// 存储过程。
  14.     /// </summary>
  15.     public class StoreProcedure
  16.     {
  17.         // 连接字符串。
  18.         private string connectionString;
  19.         // 存储过程名称。
  20.         private string storeProcedureName;
  21.         /**//// <summary>
  22.         /// 初始化 DataAccessHelper.StoreProceduer 对象。
  23.         /// </summary>
  24.         /// <param name="connectionString">数据库连接字符串。</param>
  25.         public StoreProcedure(string connectionString) {
  26.             this.connectionString = connectionString;
  27.         }
  28.         /**//// <summary>
  29.         /// 初始化 DataAccessHelper.StoreProceduer 对象。
  30.         /// </summary>
  31.         /// <param name="connectionString">数据库连接字符串。</param>
  32.         /// <param name="storeProcedureName">存储过程名称。</param>
  33.         public StoreProcedure(string connectionString, string storeProcedureName) {
  34.             this.connectionString = connectionString;
  35.             this.storeProcedureName = storeProcedureName;
  36.         }
  37.         /**//// <summary>
  38.         /// 获取或设置存储过程名称。
  39.         /// </summary>
  40.         public string StoreProcedureName {
  41.             get { return this.storeProcedureName; }
  42.             set { this.storeProcedureName = value; }
  43.         }
  44.         /**//// <summary>
  45.         /// 执行操作类(Insert/Delete/Update)存储过程。
  46.         /// </summary>
  47.         /// <param name="paraValues">传递给存储过程的参数值列表。</param>
  48.         /// <returns>受影响的行数。</returns>
  49.         public int ExecuteNonQuery(params object[] paraValues) {
  50.             using (SqlConnection connection = new SqlConnection(this.connectionString)) {
  51.                 SqlCommand command = this.CreateSqlCommand(connection);
  52.                 try {
  53.                     this.DeriveParameters(command);
  54.                     this.AssignParameterValues(command, paraValues);
  55.                     connection.Open();
  56.                     int affectedRowsCount = command.ExecuteNonQuery();
  57.                     return affectedRowsCount;
  58.                 } catch {
  59.                     throw;
  60.                 }
  61.             }
  62.         }
  63.         /**//// <summary>
  64.         /// 执行存储过程,返回 System.Data.DataTable。
  65.         /// </summary>
  66.         /// <param name="paraValues">传递给存储过程的参数值列表。</param>
  67.         /// <returns>包含查询结果的 System.Data.DataTable。</returns>
  68.         public DataTable ExecuteDataTable(params object[] paraValues) {
  69.             using (SqlConnection connection = new SqlConnection(this.connectionString)) {
  70.                 SqlCommand command = this.CreateSqlCommand(connection);
  71.                 try {
  72.                     this.DeriveParameters(command);
  73.                     this.AssignParameterValues(command, paraValues);
  74.                     SqlDataAdapter adapter = new SqlDataAdapter(command);
  75.                     DataTable dataTable = new DataTable();
  76.                     adapter.Fill(dataTable);
  77.                     return dataTable;
  78.                 } catch {
  79.                     throw;
  80.                 }
  81.             }
  82.         }
  83.         /**//// <summary>
  84.         /// 执行存储过程,填充指定的 System.Data.DataTable。
  85.         /// </summary>
  86.         /// <param name="dataTable">用于填充查询结果的 System.Data.DataTable。</param>
  87.         /// <param name="paraValues">传递给存储过程的参数值列表。</param>
  88.         public void ExecuteFillDataTable(DataTable dataTable, params object[] paraValues) {
  89.             using (SqlConnection connection = new SqlConnection(this.connectionString)) {
  90.                 SqlCommand command = this.CreateSqlCommand(connection);
  91.                 try {
  92.                     this.DeriveParameters(command);
  93.                     this.AssignParameterValues(command, paraValues);
  94.                     connection.Open();
  95.                     SqlDataAdapter adapter = new SqlDataAdapter(command);
  96.                     adapter.Fill(dataTable);
  97.                 } catch {
  98.                     throw;
  99.                 }
  100.             }
  101.         }
  102.         
  103.         /**//// <summary>
  104.         /// 执行存储过程返回 System.Data.SqlClient.SqlDataReader,
  105.         /// 在 System.Data.SqlClient.SqlDataReader 对象关闭时,数据库连接自动关闭。
  106.         /// </summary>
  107.         /// <param name="paraValues">传递给存储过程的参数值列表。</param>
  108.         /// <returns>包含查询结果的 System.Data.SqlClient.SqlDataReader 对象。</returns>
  109.         public SqlDataReader ExecuteDataReader(params object[] paraValues) {
  110.             using (SqlConnection connection = new SqlConnection(this.connectionString)) {
  111.                 SqlCommand command = this.CreateSqlCommand(connection);
  112.                 try {
  113.                     this.DeriveParameters(command);
  114.                     this.AssignParameterValues(command, paraValues);
  115.                     connection.Open();
  116.                     return command.ExecuteReader(CommandBehavior.CloseConnection);
  117.                 } catch {
  118.                     throw;
  119.                 }
  120.             }
  121.         }
  122.         /**//// <summary>
  123.         /// 执行查询,并返回查询所返回的结果集中第一行的第一列。忽略其他列或行。
  124.         /// </summary>
  125.         /// <param name="paraValues">传递给存储过程的参数值列表。</param>
  126.         /// <returns>结果集中第一行的第一列或空引用(如果结果集为空)。</returns>
  127.         public object ExecuteScalar(params object[] paraValues) {
  128.             using (SqlConnection connection = new SqlConnection(this.connectionString)) {
  129.                 SqlCommand command = this.CreateSqlCommand(connection);
  130.                 try {
  131.                     this.DeriveParameters(command);
  132.                     this.AssignParameterValues(command, paraValues);
  133.                     connection.Open();
  134.                     return command.ExecuteScalar();
  135.                 } catch {
  136.                     throw;
  137.                 }
  138.             }
  139.         }
  140.         /**//// <summary>
  141.         /// 从在 System.Data.SqlClient.SqlCommand 中指定的存储过程中检索参数信息并填充指定的 
  142.         /// System.Data.SqlClient.SqlCommand 对象的 System.Data.SqlClient.SqlCommand.Parameters 集合。
  143.         /// </summary>
  144.         /// <param name="sqlCommand">将从其中导出参数信息的存储过程的 System.Data.SqlClient.SqlCommand 对象。</param>
  145.         internal void DeriveParameters(SqlCommand sqlCommand) {
  146.             try {
  147.                 sqlCommand.Connection.Open();
  148.                 SqlCommandBuilder.DeriveParameters(sqlCommand);
  149.                 sqlCommand.Connection.Close();
  150.             } catch {
  151.                 if (sqlCommand.Connection != null) {
  152.                     sqlCommand.Connection.Close();
  153.                 }
  154.                 throw;
  155.             }
  156.         }
  157.         // 用指定的参数值列表为存储过程参数赋值。
  158.         private void AssignParameterValues(SqlCommand sqlCommand, params object[] paraValues) {
  159.             if (paraValues != null) {
  160.                 if ((sqlCommand.Parameters.Count - 1) != paraValues.Length) {
  161.                     throw new ArgumentNullException("The number of parameters does not match number of values for stored procedure.");
  162.                 }
  163.                 for (int i = 0; i < paraValues.Length; i++) {
  164.                     sqlCommand.Parameters[i + 1].Value = (paraValues[i] == null) ? DBNull.Value : paraValues[i];
  165.                 }
  166.             }
  167.         }
  168.         // 创建用于执行存储过程的 SqlCommand。
  169.         private SqlCommand CreateSqlCommand(SqlConnection connection) {
  170.             SqlCommand command = new SqlCommand(this.storeProcedureName, connection);
  171.             command.CommandType = CommandType.StoredProcedure;
  172.             return command;
  173.         }
  174.     }
  175. }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值