Asp.net调试点滴(莫名其妙的问题)!...

给一家公司维护网站,老板要求增加新的模块,整个系统在本地调试完成,没有任何问题。可是上传到服务器报错如下:

“/”应用程序中的服务器错误。
--------------------------------------------------------------------------------
name
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: System.IndexOutOfRangeException: name
源错误:
执行当前 Web 请求期间生成了未处理的异常。可以使用下面的异常堆栈跟踪信息确定有关异常原因和发生位置的信息。 
堆栈跟踪:
[IndexOutOfRangeException: name]
   System.Data.Common.FieldNameLookup.GetOrdinal(String fieldName) +55
   System.Data.SqlClient.SqlDataReader.GetOrdinal(String name) +68
   System.Data.SqlClient.SqlDataReader.get_Item(String name) +10
   farmer.default1.Page_Load(Object sender, EventArgs e)
   System.Web.UI.Control.OnLoad(EventArgs e) +67
   System.Web.UI.Control.LoadRecursive() +35
   System.Web.UI.Page.ProcessRequestMain() +750
--------------------------------------------------------------------------------
版本信息: Microsoft .NET Framework 版本:1.1.4322.2300; ASP.NET 版本:1.1.4322.2300

费了我好几天的时间来找错误,没有结果,老板催得的急。最后我迫不得已把所有的代码都把它包含在
try.. catch中了,catch中我没做任何的处理,莫名其妙错误消失,老板那边交待过去了。可是错误的真正的
原因还没找到,又经过两天的努力,终于找到了错误所在
原来的开发者在程序中使用了“Select  SUBSTRING(name, 1, 8),title FROM Tablename" 的SQL语句,
而在用户数据录入时,Name字段的输入没有作限制,造成以上的原因。

而在本地调试没有问题是因为本的数据都符合这个长度,没有触发这个异常。

总结:之所以开发者采用这样的SQL语句是为了在页面上显示时美观,但不应该在SQL语句中处理,
我的解决办法将SQl语句改为"Select name,title From Tablename" ,然后,对取出的name字段的数据,
判断其长度如果超过8则作截取处理,否则不作处理。最核心的问题是设计者在进行数据库设计时有遗漏现在网站在运行中里面已经有很多数据,我也只有采用折中的办法。

转载于:https://www.cnblogs.com/chenwei618-1981/archive/2006/12/12/589789.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值