Foxtable(狐表)用户栏目专家坐堂 → System.IndexOutOfRangeException: 索引超出了数组界限


  共有4181人关注过本帖树形打印复制链接

主题:System.IndexOutOfRangeException: 索引超出了数组界限

帅哥哟,离线,有人找我吗?
cnsjroom
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
System.IndexOutOfRangeException: 索引超出了数组界限  发帖心情 Post By:2022/12/15 9:02:00 [只看该作者]

System.Reflection.TargetInvocationException: 调用的目标发生了异常。 ---> System.IndexOutOfRangeException: 索引超出了数组界限。
麻烦老师帮忙看看   主要是在台账中如果没有编号  就会出现这个……如果已经有了类似bazbdy001的编号就不会出现

 

当前代码:

Dim lb As String = dr("分类代码")
Dim idx As Integer
Dim cmd As New S QLC ommand
cmd.Con nect io nNa me = "主数据源"
cmd.CommandText = "Se lect * From 台账 where 分类代码 = '" & lb & "' And [_Identify] <>''"
Dim dt As DataTable = cmd.ExecuteReader()
Dim dr1 As DataRow = dt.DataRows(dt.DataRows.Count - 1) '获得最后一行
output.show(dr1("_Identify"))
If dr1("编号").StartsWith("BZZB" & lb) = False '如果单据编号前缀不符
    cmd.CommandText = "sele ct Max(编号) from 台账 where 分类代码 = '" & lb & "' And [_Identify] <> " & dr1("_Identify")
    Dim max As String
    max = cmd.ExecuteScalar()
    output.show(max)
    If max > "" Then '如果存在最大编号
        idx = CInt(max.Substring(6,3)) + 1 '获得最大编号的后三位顺序号,并加1
    Else
        idx = 1 '否则顺序号等于1
    End If
    dr("编号")=("BAZB" & lb & Format(idx,"000"))
    dr.Save
End If

 

运行提示:

错误的事件名称项目,HttpRequest
System.Reflection.TargetInvocationException: 调用的目标发生了异常。 ---> System.IndexOutOfRangeException: 索引超出了数组界限。
   在 eWebSer.form673_save_Ajax(Request rq)
   --- 内部异常堆栈跟踪的结尾 ---
   在 Microsoft.VisualBasic.CompilerServices.Symbols.Container.InvokeMethod(Method TargetProcedure, Object[] Arguments, Boolean[] CopyBack, BindingFlags Flags)
   在 Microsoft.VisualBasic.CompilerServices.NewLateBinding.CallMethod(Container BaseReference, String MethodName, Object[] Arguments, String[] ArgumentNames, Type[] TypeArguments, Boolean[] CopyBack, BindingFlags InvocationFlags, Boolean ReportErrors, ResolutionFailure& Failure)
   在 Microsoft.VisualBasic.CompilerServices.NewLateBinding.ObjectLateCall(Object Instance, Type Type, String MemberName, Object[] Arguments, String[] ArgumentNames, Type[] TypeArguments, Boolean[] CopyBack, Boolean IgnoreReturn)
   在 Microsoft.VisualBasic.CompilerServices.NewLateBinding.LateCall(Object Instance, Type Type, String MemberName, Object[] Arguments, String[] ArgumentNames, Type[] TypeArguments, Boolean[] CopyBack, Boolean IgnoreReturn)
   在 UserCode.HttpRequest(RequestEventArgs e)
2022-12-15 09:00:37


 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106454 积分:541417 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/12/15 9:07:00 [只看该作者]

idx = CInt(max.Substring(max.length - 3)) + 1 '获得最大编号的后三位顺序号,并加1

 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)idx = CInt(max.Substring(max.lengt...  发帖心情 Post By:2022/12/15 10:30:00 [只看该作者]

Dim lb As String = dr("分类代码")
    Dim idx As Integer
    Dim cmd As New SQLCommand
    cmd.Conn ecti onNa me = "主数据源"
    cmd.CommandText = "Se lect * From 台账 where 分类代码 = '" & lb & "' And [_Identify] <>''"
    Dim dt As DataTable = cmd.ExecuteReader()
    Dim dr1 As DataRow
    If dr1 IsNot Nothing Then    如果找到行  那就获取最大编号
        dr1= dt.DataRows(dt.DataRows.Count - 1) '获得最后一行
        output.show(dr1("_Identify"))
        cmd.CommandText = "sel ect Max(编号) from 台账 where 分类代码 = '" & lb & "' And [_Identify] <> " & dr1("_Identify")
        Dim max As String
        max = cmd.ExecuteScalar()
        If max > "" Then '如果存在最大编号
            idx = CInt(max.Substring(max.length - 3)) + 1  '获得最大编号的后三位顺序号,并加1
        Else
            idx = 1 '否则顺序号等于1
        End If
        dr("编号")=(lb & Format(idx,"000"))
    Else   如果找不到行  那就直接定义为1 并开始编号
        idx = 1 '否则顺序号等于1
        dr("编号")=(lb & Format(idx,"000"))
    End If

 

 

继续麻烦老师一下    我当前得到的编号永远都是001


 回到顶部
帅哥,在线噢!
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106454 积分:541417 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/12/15 10:40:00 [只看该作者]

新编号没有保存,SQL只能获取后台已保存数据

 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)新编号没有保存,SQL只能获取后台已保...  发帖心情 Post By:2022/12/15 11:01:00 [只看该作者]

Dim dr As DataRow = rq.result '返回当前保存的数据行,可再处理数据
If dr IsNot Nothing Then
    Dim lb As String = dr("分类代码")
    Dim idx As Integer
    Dim cmd As New SQ LC ommand
    cmd.Conn ecti onN ame = "主数据源"
    cmd.CommandText = "Se lect * From 台账 where 分类代码 = '" & lb & "' And [_Identify] <>''"
    Dim dt As DataTable = cmd.ExecuteReader()
    Dim dr1 As DataRow
 If dr1 IsNot Nothing Then
        dr1= dt.DataRows(dt.DataRows.Count - 1) '获得最后一行
        output.show(dr1("_Identify"))
        cmd.CommandText = "sele ct Max(编号) from 台账 where 分类代码 = '" & lb & "' And [_Identify] <> " & dr1("_Identify")
        Dim max As String
        max = cmd.ExecuteScalar()
        If max > "" Then '如果存在最大编号
            idx = CInt(max.Substring(max.length - 3)) + 1  '获得最大编号的后三位顺序号,并加1
        Else
            idx = 1 '否则顺序号等于1
        End If
        dr("编号")=lb & Format(idx,"000")
    Else
        idx = 1 '否则顺序号等于1
        dr("编号")=lb & Format(idx,"000")
    End If
    dr.Save
End If

 

 

老师保存了的   也是一样的不递增……

[此贴子已经被作者于2022/12/15 11:05:10编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106454 积分:541417 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/12/15 11:05:00 [只看该作者]

到数据库里看看最新的编号保存后有没有

 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)到数据库里看看最新的编号保存后有没...  发帖心情 Post By:2022/12/15 11:40:00 [只看该作者]

经核查   代码运行后   对应的第一个编号是保存到了数据库中的编号字段的

还得麻烦老师 指导下:或者是将下述代码  用其他方式实现类似效果

 

Dim dr As DataRow = rq.result '返回当前保存的数据行,可再处理数据
If dr IsNot Nothing Then
    Dim lb As String = dr("分类代码")
    Dim idx As Integer
    Dim cmd As New SQ LC ommand
    cmd.Conn ecti onN ame = "主数据源"
    cmd.CommandText = "Se lect * From 台账 where 分类代码 = '" & lb & "' And [_Identify] <>''"
    Dim dt As DataTable = cmd.ExecuteReader()
    Dim dr1 As DataRow
 If dr1 IsNot Nothing Then
        dr1= dt.DataRows(dt.DataRows.Count - 1) '获得最后一行
        output.show(dr1("_Identify"))
        cmd.CommandText = "sele ct Max(编号) from 台账 where 分类代码 = '" & lb & "' And [_Identify] <> " & dr1("_Identify")
        Dim max As String
        max = cmd.ExecuteScalar()
        If max > "" Then '如果存在最大编号
            idx = CInt(max.Substring(max.length - 3)) + 1  '获得最大编号的后三位顺序号,并加1
        Else
            idx = 1 '否则顺序号等于1
        End If
        dr("编号")=lb & Format(idx,"000")
    Else
        idx = 1 '否则顺序号等于1
        dr("编号")=lb & Format(idx,"000")
    End If
    dr.Save
End If


 回到顶部
帅哥,在线噢!
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106454 积分:541417 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/12/15 11:45:00 [只看该作者]

学会调试

 If dr1 IsNot Nothing Then
        dr1= dt.DataRows(dt.DataRows.Count - 1) '获得最后一行
        output.show(dr1("_Identify"))
        cmd.CommandText = "sele ct Max(编号) from 台账 where 分类代码 = '" & lb & "' And [_Identify] <> " & dr1("_Identify")
        Dim max As String
        max = cmd.ExecuteScalar()
msgbox(max )
        If max > "" Then '如果存在最大编号
            idx = CInt(max.Substring(max.length - 3)) + 1  '获得最大编号的后三位顺序号,并加1
        Else
            idx = 1 '否则顺序号等于1
        End If
msgbox(idx )
        dr("编号")=lb & Format(idx,"000")
    Else
        idx = 1 '否则顺序号等于1
        dr("编号")=lb & Format(idx,"000")
    End If
msgbox(dr("编号"))
    dr.Save
End If

 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)学会调试 If dr1 IsNot Nothing...  发帖心情 Post By:2022/12/15 12:41:00 [只看该作者]

当前代码如下:

 

Public Sub form673_save_Ajax(rq As Request)
Me.tablesave(rq) '保存数据表
Dim dr As DataRow = rq.result '返回当前保存的数据行,可再处理数据
If dr IsNot Nothing Then
    Dim lb As String = dr("分类代码")
    Dim idx As Integer
    Dim cmd As New SQLCommand
    cmd.Conn ect ion Name = "主数据源"
   
    cmd.CommandText = "Se lect * From 办案装备_管理台账 where 分类代码 = '" & lb & "' And [_Identify] <>''"
    Dim dt As DataTable = cmd.ExecuteReader()
    If dt.DataRows.Count>1 Then
        Dim dr1 As DataRow
        dr1= dt.DataRows(dt.DataRows.Count - 1) '获得最后一行
        If dr1 IsNot Nothing Then
            output.show(dr1("_Identify"))
            cmd.CommandText = "sele ct Max(编号) from 办案装备_管理台账 where 分类代码 = '" & lb & "' And [_Identify] <> " & dr1("_Identify") 
            Dim max As String
            max = cmd.ExecuteScalar()
            If max > "" Then '如果存在最大编号
                idx = CInt(max.Substring(max.length - 3)) + 1  '获得最大编号的后三位顺序号,并加1
            Else
                idx = 1 '否则顺序号等于1
            End If
        Else
            idx = 1 '否则顺序号等于1
        End If
        dr("编号")=lb & Format(idx,"000")
        dr.Save
    End If
End If
rq.e.WriteString(rq.msg.ToString)
End Sub

 

 运行后出现两个重号后会新增一个号     


图片点击可在新窗口打开查看此主题相关图片如下:11.png
图片点击可在新窗口打开查看

上述问题有没有办法解决呢?或者有没有直接SQL语句可以直接实现对应的编号按类别不同递增呢?


 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)学会调试 If dr1 IsNot Nothing...  发帖心情 Post By:2022/12/15 12:56:00 [只看该作者]

代码二:

Public Sub form673_save_Ajax(rq As Request)
Me.tablesave(rq) '保存数据表
Dim dr As DataRow = rq.result '返回当前保存的数据行,可再处理数据
If dr IsNot Nothing Then
    Dim lb As String = dr("分类代码")
    Dim idx As Integer
    Dim cmd As N ew S QLCommand
    cmd.Conne ctio nName = "主数据源"
    cmd.CommandText = "Sele ct * From 办案装备_管理台账 where 分类代码 = '" & lb & "' "
    Dim dt As DataTable = cmd.ExecuteReader()
    If dt.DataRows.Count>1 Then
        cmd.CommandText = "sel ect Max(编号) from 办案装备_管理台账 where 分类代码 = '" & lb & "'"
        Dim max As String
        max = cmd.ExecuteScalar()
        If max > "" Then '如果存在最大编号
            idx = CInt(max.Substring(max.length - 3)) + 1  '获得最大编号的后三位顺序号,并加1
        Else
            idx = 1 '否则顺序号等于1
        End If
    Else
        idx = 1 '否则顺序号等于1
    End If
    If dr("编号")<> Nothing Then
    Else
        dr("编号")=lb & Format(idx,"000")
    End If
    dr.Save
End If
rq.e.WriteString(rq.msg.ToString)
End Sub


 回到顶部
总数 12 1 2 下一页