1

这是我的代码-

 using (SqlDataReader sqlDataReader = ExecuteReader(CommandType.StoredProcedure, StoredProcedures.AuthenticateUser, sqlParameter))
        {
            isAuthenticated = Convert.ToBoolean(sqlParameter[2].Value);
            if (isAuthenticated)
            {
                if (sqlDataReader.Read())
                {
                    User = new UserEntity();
                    DbHelper.GetEntity(sqlDataReader, User);
                }                 
            }
        }

我总是得到isAuthenticated错误,因为一直sqlParameter[2].Value为空,但是当我用它执行查询时,ExecuteNonQuery它给了我值,但在这种情况下,我无法填写 entity.suggest 请。

4

1 回答 1

0

我相信在您从 DataReader 读取所有结果之前,输出参数不可用。试试这个:

using (SqlDataReader sqlDataReader = ExecuteReader(CommandType.StoredProcedure, 
       StoredProcedures.AuthenticateUser, sqlParameter))
{
     var newUser = new UserEntity();
     if (sqlDataReader.Read())
     {             
         DbHelper.GetEntity(sqlDataReader, User);
     }

     isAuthenticated = Convert.ToBoolean(sqlParameter[2].Value);         
     if (isAuthenticated)
     {
         User = newUser;
     }
 }
于 2011-01-10T12:28:55.843 回答