sql server数据库中自定义函数的问题 100

publicstaticTimeZoneInformationGetTimeZoneById(inttimeZoneId){if(timeZoneId==SpecialI... publicstaticTimeZoneInformationGetTimeZoneById(int timeZoneId)
{
if (timeZoneId == SpecialId_CurrentTimeZone)
{
timeZoneId = m_currentTimeZoneId;
}
elseif ((timeZoneId < 0) || (timeZoneId > m_timeZones.Count))
{
timeZoneId = GetTimeZoneIdByChecksum(timeZoneId);
if (timeZoneId == SpecialId_CurrentTimeZone)
{
timeZoneId = m_currentTimeZoneId;
}
}
returnm_timeZones[timeZoneId];
}

报错的函数大概就是上面这样 报错信息是
消息 6522,级别 16,状态 2,第 1 行
在执行用户定义例程或聚合“TimeZoneDisplayName”期间出现 .NET Framework 错误:
System.ArgumentOutOfRangeException: 索引超出范围。必须为非负值并小于集合大小。
参数名: index
System.ArgumentOutOfRangeException:
在 ArchestrA.TimeExtensions.TimeZones.GetTimeZoneById(Int32 timeZoneId)


情况是这样的 这个函数是附加在数据库的程序集里的 实际已经封装在dll里了 上面的代码是我用反编译工具出来的
这个数据库是我从一个win2008 32位的虚拟机上的sql server 2008sp1上备份下来 然后还原到一台win7 64位 sql server2012 64位的数据库上
现在遇到的问题是虚拟机上这个函数可以正常使用 但是我还原到sql2012 64位数据库上 调用这个函数时传入参数是正数是正常 传入参数是负数就报以上这个错
哪位大侠知道
展开
 我来答
lsyuan_hello
2012-09-27 · TA获得超过1691个赞
知道小有建树答主
回答量:663
采纳率:0%
帮助的人:692万
展开全部
timeZoneId = GetTimeZoneIdByChecksum(timeZoneId);

GetTimeZoneIdByChecksum 把这个方法内容贴出来看看噻
playsenlin
2012-09-19 · TA获得超过101个赞
知道小有建树答主
回答量:438
采纳率:0%
帮助的人:237万
展开全部
站个位置。有空来弄。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
谈论用户名
2012-09-26 · TA获得超过1189个赞
知道小有建树答主
回答量:3981
采纳率:21%
帮助的人:1053万
展开全部
你这样描述,难道和系统有关,与操作系统的位数有关了?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式