我有一个存储过程,它返回我使用 GetReader 调用的两个记录集。我迭代第一个,调用 IDataReader.NextResult(),然后迭代第二个。
我在 sp 中为输出参数赋值,但是当我在阅读器完成后检查值时,我的输出参数为空。看起来像一个错误。我不想使用选择,因为我不喜欢软糖。一些片段...
...
sp.Command.AddParameter("@SelectedTabID", selectedTabID, DbType.Int32);
sp.Command.AddParameter("@CurrentTabID", 0, DbType.Int32, ParameterDirection.Output);
sp.Command.AddParameter("@TypeID", 0, DbType.Int32, ParameterDirection.Output);
(注意这样做或使用 AddOutputParameter() 会产生相同的结果)
...
using(IDataReader reader = sp.GetReader())
{
while (reader.Read()) {...}
if (reader.NextResult()) {while (reader.Read()) {...}}
}
...
int one = (int)sp.OutputValues[0]; //null expected an int
int two = (int)sp.OutputValues[1]; //null expected an int
期待一些智慧的宝石:)