OdbcConnection con = new OdbcConnection("Driver={SQL Server};server=PC-200201070359;uid=sa;pwd=123;database=test;"); try
{
con.Open();
OdbcCommand command = new OdbcCommand();
command.Connection = con;
command.CommandType = CommandType.StoredProcedure;
//command.CommandText = "MaxAge"; //存儲過程名稱
command.CommandText = "{call MaxAge (?, ?,?)}";
//輸入參數
OdbcParameter para = new OdbcParameter("@Name1", OdbcType.NVarChar, 10);
para.Value = "James";
command.Parameters.Add(para);
//輸入參數
para = new OdbcParameter("@Name2", OdbcType.NVarChar, 10);
para.Value = "Mary";
command.Parameters.Add(para);
//輸出參數(參數名稱大小寫無關)
para = new OdbcParameter("@MaxAge", OdbcType.Int, 4);
para.Direction = ParameterDirection.Output;
command.Parameters.Add(para);
int i = command.ExecuteNonQuery(); //執行成功返回-1
string k = command.Parameters["@Maxage"].Value.ToString();
}
catch (Exception ex)
{
//throw;
}
可能遇到的問題:
使用ODBC方法,只能方法時會報這樣的異常:ERROR [42000] [Microsoft][ODBC SQL Server Driver][SQL Server]過程 'MaxAge' 需要參數 '@Name1',但未提供該參數。
解決辦法:將command.CommandText = "MaxAge"; //存儲過程名稱 改為 command.CommandText = "{call MaxAge (?, ?,?)}";即可,目前原因未知;前面的方法在sqlclient中是可用的
更多可參看鏈接:http://www.cnblogs.com/gossip/archive/2009/06/15/1503884.html