System.FormatException: 输入字符串的格式不正确是什么错误?

PPLUNCLE 2004-07-15 09:07:32
过程体:
public string D_GetMaxBM(string ParentBM)
{
string sql;
string ResultStr;
ResultStr="";
int ResultStrlen;
int tResultStr;
int Plen=ParentBM.Length+1; //得到父类编号长度并加1,因为多一个 “-”
string tempP=ParentBM+"-"; //父类编号后面加上一个“-”
sql="select max(substr(BM,"+ Plen +",length(BM))) as BM from CL_CKCB where BM like '"+ tempP.ToString() +"%'";
DataTable temptb=this.ListBySql(sql);
string maxBM = temptb.Rows[0]["BM"].ToString();
if(maxBM!=null)
{
tResultStr=System.Convert.ToInt32(temptb.Rows[0]["BM"].ToString())+1; //取得最大值+1
}
else
{
tResultStr=1 ;
}
ResultStr=tResultStr.ToString();
ResultStrlen=ResultStr.Length;
if(ResultStrlen< 3)
{
for(int i=0;i< 3-ResultStrlen;i++)
{
ResultStr="0"+ResultStr.ToString();
}
}
else
{
ResultStr=ResultStr;
}


return ResultStr; //返回
}

调用运行报错:

输入字符串的格式不正确。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.FormatException: 输入字符串的格式不正确。

源错误:


行 41: if(maxBM!=null)
行 42: {
行 43: tResultStr=System.Convert.ToInt32(temptb.Rows[0]["BM"].ToString())+1; //取得最大值+1
行 44: }
行 45: else


请问这个是什么错误啊,我已经判断了maxBM是不是为null了啊,怎么还是报这个错了?
还请各位指点
...全文
268 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
八爪鱼-杭州 2004-07-15
  • 打赏
  • 举报
回复
temptb.Rows[0]["BM"].ToString()得到的不是一个可以转换的数字字符串
比如可能得到了一个123.a45这样的

62,256

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧