将 expression 转换为数据类型 int 时发生算术溢出错误。 
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.Data.SqlClient.SqlException: 将 expression 转换为数据类型 int 时发生算术溢出错误。源错误: 
行 432:
行 433: SqlDataReader der=com.ExecuteReader();
行 434: if(der.Read())
行 435: {
行 436: try
 
------------------------------------------------------------------------------其中一段代码(包括SQL语名) ,怎么解决呢string sql="select   Sum(db.filesize) AS  filecount  from [db] "+wh;
SqlCommand com=new SqlCommand(sql,objconn); SqlDataReader der=com.ExecuteReader();
if(der.Read())
{
try
{
fcount=Convert.ToInt32(der["filecount"]);
}
catch
{
fcount=0;
}
}
else
{
fcount=0;
}

解决方案 »

  1.   

    行 434: if(der.Read())  出现错误
      

  2.   

    不会十if(der.Read())  出错,
    应该是fcount=Convert.ToInt32(der["filecount"]);错了,
    改用一个大点得类型如Convert.ToUInt64(der["filecount"])试试
      

  3.   

    Sum(db.filesize)的值超出了int32的范围了
      

  4.   

    同意楼上各位的,不应该是if(der.Read())出错

    long  fcount=Convert.ToInt64();试试
      

  5.   

    换了long 也不行,应该是 chg515(瞎玩)  的答案,但如何解决呢?
      

  6.   

    Sum(db.filesize)的值超出了int32的范围了 如何解决啊
      

  7.   

    decimal fcount=Convert.ToDecimal(der["filecount"]);