none
sql server数据库中自定义函数索引超出范围的问题 RRS feed

  • 问题

  • 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位数据库上 调用这个函数时传入参数是正数是正常 传入参数是负数就报以上这个错
    哪位大侠知道
    2012年9月18日 3:08