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:16

答案

  • 调试一下GetTimeZoneIdByChecksum

    错误信息很明显了

    System.ArgumentOutOfRangeException: 索引超出范围。必须为非负值并小于集合大小。

    例如一个字符串长度为n,你要截取位置的话不能是负数,不能大于n。

    这个索引范围也是同理。

    2012年9月24日 12:14
    版主

全部回复

  • 关注一下

    给我写信: QQ我:点击这里给我发消息

    2012年9月18日 13:52
  • 应该是传入参数给内置的一些函数如果是负数就报错了

    比如GetTimeZoneIdByChecksum函数


    给我写信: QQ我:点击这里给我发消息

    2012年9月18日 13:54
  • 你好,

    请问GetTimeZoneIdByChecksum()是个怎样的函数?是否可checksum()有关系呢?

    Thanks.


    Please remember to mark the replies as answers if they help and unmark them if they provide no help. This can be beneficial to other community members reading the thread.

    2012年9月20日 14:56
    版主
  • 调试一下GetTimeZoneIdByChecksum

    错误信息很明显了

    System.ArgumentOutOfRangeException: 索引超出范围。必须为非负值并小于集合大小。

    例如一个字符串长度为n,你要截取位置的话不能是负数,不能大于n。

    这个索引范围也是同理。

    2012年9月24日 12:14
    版主