C#如何执行存储过程

 以Oracle为例,其它数据库仅改变数据库对象就可以。下面是带参数的,不带参数的话paramete为null即可。

参数对应

 public static int UploadStartCloseSoftInfo(string[] args)       {                         OracleParameter parameter1 = new OracleParameter(参数名1, OracleType.类型);            parameter1.Value =类型转换(args[0]);                                 OracleParameter parameter2 = new OracleParameter(参数名2, OracleType.类型);            parameter2.Value =类型转换(args[1]);                  ...  ...          OracleParameter parametern = new OracleParameter(参数名n, OracleType.类型);            parametern.Value =类型转换(args[n-1]);          OracleParameter[] parameter                            = {parameter1,parameter2,..., parametern};                            return SDProvider.RunProcedure(存储过程名, parameter);               }        }    }    

执行

public class SDProvider    {           public static string GetConnectionString()           {               string conStr =连接数据库字符串;               return conStr ;           }                      public static int RunProcedure(string  prName, IDataParameter[] parameters)           {               try               {                   using(OracleConnection connection=                  new OracleConnection(GetConnectionString()))                    {                        connection.Open();                        OracleCommand command =                       BuildQueryCommand(connection, storedProcName, parameters);                           return  command.ExecuteNonQuery();                   }               }               catch               {               }               return 0;           }            private static OracleCommand BuildQueryCommand                                        (OracleConnection connection,                                       string storedProcName,                                        IDataParameter[]parameters)            {              OracleCommand command = new OracleCommand(storedProcName, connection);              command.CommandType = CommandType.StoredProcedure;              if(parameters!=null)            {               foreach (OracleParameter parameter in parameters)                 {                   command.Parameters.Add(parameter);                 }              }              return command;            }  }  

注意:

   1、存储过程名正确。

   2、参数名1,参参数名2,这些的名字要和存储过程中的参数名一样,顺序和类型均要对应一致。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值