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位数据库上 调用这个函数时传入参数是正数是正常 传入参数是负数就报以上这个错
哪位大侠知道 展开
{
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位数据库上 调用这个函数时传入参数是正数是正常 传入参数是负数就报以上这个错
哪位大侠知道 展开
3个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询