1

here my code-

 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);
                }                 
            }
        }

I always get isAuthenticated as false because sqlParameter[2].Value is null all the time but when I execute my query with ExecuteNonQuery it gives me the value but in that case I can not fill the entity.suggest please.

ppp
  • 303
  • 2
  • 9
  • 22

1 Answers1

0

I believe that output parameters are not available until you have read all the results from the DataReader. Try this instead:

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;
     }
 }
Martin Brown
  • 24,692
  • 14
  • 77
  • 122