Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,037

HOME > .NET Framework > Forum > ERROR แบบนี้มันหมายความว่ายังไงครับ แปลกใจมาก แก้ก็ไม่ได้ VB 2008+SQL Server 2000



 

ERROR แบบนี้มันหมายความว่ายังไงครับ แปลกใจมาก แก้ก็ไม่ได้ VB 2008+SQL Server 2000

 



Topic : 051947

Guest




ผมก็ไม่รู้จะอธิบาย ERROR ว่ายังไง
คือประมาณว่า...ผมสั่งให้วนลูปเรียกดูข้อมูล (วนประมาณ 5 รอบ (ตามข้อมูล) ก็ยังได้ แต่พอมันวนรอบที่ 6 มันจะ ERROR )
และข้อมูลตรงที่มัน ERROR ผมเข้าไปดูใน DB มันก็มีข้อมูลนะครับ...ไม่ได้เป็นค่าว่าง หรือไม่มีค่าเลย

ช่วยดูทีครับ...

Eroore


นี่เป็น Code ครับ

Code (VB.NET)
ListView3.Items.Clear()

        Dim row As Integer = 0
        Dim ProOrder_Bom, fg_fg_Bom As String

        'วนลูปแถวทั้งหมดของ ListView
        For row = 0 To Me.ListView2.Items.Count - 1

           ' If row = 5 Then
                'Exit For
           ' End If

            ProOrder_Bom = Me.ListView2.Items(row).SubItems(2).Text
            fg_fg_Bom = Me.ListView2.Items(row).SubItems(9).Text

            'FG_FG = fg_fg_Bom
            sql = "SELECT Count(Pro_Order)AS C_ProOrder, Pro_Order"
            sql &= " FROM MB51"
            sql &= " WHERE Plnt='" & txt_plant.Text & "' and MvT=261 and Material  NOT BETWEEN '10000000' AND '19999999' and Pro_Order='" & ProOrder_Bom & "'"
            'sql &= " Order by Plnt asc, Pro_Order asc, Material asc, Batch asc"
            sql &= " GROUP BY Pro_Order"


            Dim cn As New SqlConnection(strConxx)
            If cn.State = ConnectionState.Open Then cn.Close()
            cn.Open()

            Dim comx As New SqlCommand(sql, cn)

            Dim dr_xz As SqlDataReader
            dr_xz = comx.ExecuteReader
            Dim k_xz As Integer = 0

            If dr_xz.HasRows <> 0 Then
                dr_xz.Read()
                k_xz = dr_xz.Item("C_ProOrder").ToString()
                'MsgBox(dr_xz.Item("C_ProOrder").ToString())
            Else
                k_xz = 0
            End If

            '''''''''''''''''''''''''''''''เริ่ม เงือนไข'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
            If k_xz > 0 Then


                sql = "SELECT Pro_Order, Plnt, Material, Description, Mat_Doc, Batch, Qty_in_UnE, EUn, Postg_Date"
                sql &= " FROM MB51"
                sql &= " WHERE Plnt='" & txt_plant.Text & "' and MvT=261 and Material  NOT BETWEEN '10000000' AND '19999999' and Pro_Order='" & ProOrder_Bom & "'"
                sql &= " Order by Plnt asc, Pro_Order asc, Material asc, Batch asc"

                If cn.State = ConnectionState.Open Then cn.Close()
                cn.Open()

                Dim com As New SqlCommand(sql, cn)
                'com.CommandTimeout = 0

                Dim dr_x As SqlDataReader

                dr_x = com.ExecuteReader

                Dim k_x As Integer = 0

                If dr_x.HasRows <> 0 Then
                    Do While dr_x.Read()
                        k_x = k_x + 1

                        If k_x = 1 Then

                            Child_name = dr_x.Item("Material").ToString()
                            Child_Description = dr_x.Item("Description").ToString()
                            Child_ProOrder = dr_x.Item("Pro_Order").ToString()
                            Child_Plant = dr_x.Item("Plnt").ToString()
                            Child_MatDoc = dr_x.Item("Mat_Doc").ToString()
                            Child_Batch = dr_x.Item("Batch").ToString()
                            Child_Qty = dr_x.Item("Qty_in_UnE").ToString()
                            Child_EUn = dr_x.Item("EUn").ToString()
                            Child_PostingDate = Fdate.dtformatCurrentInfo_with_ddmmyyyy(dr_x.Item("Postg_Date").ToString())

                            Qty_Sum_Child = Child_Qty
                            Postg_Date_Sum_Child = Child_PostingDate

                            If k_x = k_xz Then

                                check_12 = Mid(Child_name, 1, 1)
                                If check_12 = "1" Or check_12 = "2" Then
                                    Check_FGx = "0"
                                Else
                                    Check_FGx = "1"
                                End If

                                Dim newItem As New ListViewItem(New String() {Child_name, Child_Description, Child_ProOrder, Child_Plant, Child_MatDoc, Child_Batch, Qty_Sum_Child, Child_EUn, Postg_Date_Sum_Child, fg_fg_Bom, Check_FGx})
                                Me.ListView3.Items.Add(newItem)

                            End If
                            '''''''''''''''''''''''''''''''''''''''''''
                        Else

                            Child_namex = dr_x.Item("Materail").ToString()
                            Child_Descriptionx = dr_x.Item("Description").ToString()
                            Child_ProOrderx = dr_x.Item("Pro_Order").ToString()
                            Child_Plantx = dr_x.Item("Plnt").ToString()
                            Child_MatDocx = dr_x.Item("Mat_Doc").ToString()
                            Child_Batchx = dr_x.Item("Batch").ToString()
                            Child_Qtyx = dr_x.Item("Qty_in_UnE").ToString()
                            Child_EUnx = dr_x.Item("EUn").ToString()
                            Child_PostingDatex = Fdate.dtformatCurrentInfo_with_ddmmyyyy(dr_x.Item("Postg_Date").ToString())

                            If Child_namex = Child_name And Child_Batchx = Child_Batch And Child_ProOrderx = Child_ProOrder Then

                                Qty_Sum_Child = Qty_Sum_Child + Child_Qtyx

                                If Child_PostingDatex <= Child_PostingDate Then
                                    Postg_Date_Sum_Child = Child_PostingDatex
                                End If

                                If k_x = k_xz Then

                                    check_12 = Mid(Child_name, 1, 1)
                                    If check_12 = "1" Or check_12 = "2" Then
                                        Check_FGx = "0"
                                    Else
                                        Check_FGx = "1"
                                    End If

                                    Dim newItem As New ListViewItem(New String() {Child_name, Child_Description, Child_ProOrder, Child_Plant, Child_MatDoc, Child_Batch, Qty_Sum_Child, Child_EUn, Postg_Date_Sum_Child, fg_fg_Bom, Check_FGx})
                                    Me.ListView3.Items.Add(newItem)

                                End If

                                Child_name = Child_namex
                                Child_Description = Child_Descriptionx
                                Child_ProOrder = Child_ProOrderx
                                Child_Plant = Child_Plantx
                                Child_MatDoc = Child_MatDocx
                                Child_Batch = Child_Batch
                                Child_Qty = Child_Qtyx
                                Child_EUn = Child_EUnx
                                Child_PostingDate = Child_PostingDatex

                            Else

                                If k_x = k_xz Then

                                    check_12 = Mid(Child_name, 1, 1)
                                    If check_12 = "1" Or check_12 = "2" Then
                                        Check_FGx = "0"
                                    Else
                                        Check_FGx = "1"
                                    End If

                                    Dim newItem As New ListViewItem(New String() {Child_name, Child_Description, Child_ProOrder, Child_Plant, Child_MatDoc, Child_Batch, Qty_Sum_Child, Child_EUn, Postg_Date_Sum_Child, fg_fg_Bom, Check_FGx})
                                    Me.ListView3.Items.Add(newItem)

                                End If

                            End If '''''''''''''''''''''''''''''''''''''''''''''''

                        End If

                    Loop

                End If
                cn.Close()


            End If
           

            '''''''''''''''''''''''''''''''''''''''''''''''''''ในเงื่อนใข จบ'''''''''''''''''''''''''''''''''''''



            cn.Close()

            '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

        Next




Tag : .NET, VB.NET







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2010-11-20 16:44:17 By : พงศธร View : 1211 Reply : 3
 

 

No. 1



โพสกระทู้ ( 538 )
บทความ ( 3 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์


จาก Error มันบอกว่าหมายเลข index ออกนอกขอบเขตที่ประกาศไว้ คงต้องไล่ debug เป็นตัวๆ แล้วอ่ะครับว่า จากบรรทัดทีเกิด error มี object ไหนที่ใช้ index เกินหรือไม่อยู่ในขอบเขตที่กำหนดบ้าง

listbox.listitem()

ตัวแปร array

ตัวแปรจำนวนรอบที่วน

ทุกอย่างอ่ะครับ ค่อยๆไล่ดูทีละตัวครับ ไม่น่าเกี่ยวกับข้อมูล เพราะคุณ query ข้อมูลออกมาได้แล้วอย่างที่คุณว่า






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2010-11-20 17:11:35 By : salapao_codeman
 


 

No. 2

Guest


ขอบคุณครับ...ที่ช่วยอธิบาย...

เด่วจะทดสอบดู...(แต่ยังไม่มั่นใจว่าจะทำได้...จะพยายามเต็มเหนี่ยวครับ...)
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2010-11-20 20:18:16 By : พงศธร
 

 

No. 3

Guest


ทดสอบดูแล้วครับ...แต่ก็ยังเป็นเหมือนเดิม...

เท่าที่ลองสังเกตุดู....

คือตรง

if k_x = 1 then
ตรงนี้ทำ...

แต่ else
มันจะ ERror แบบนั้นเลยครับ...

ผมก็เลยลอง check ดู เอาเฉพาะ K_xz มีค่า =1 มาวนดู (คือ ถ้ามากกว่าานี้ ก็ข้ามไป ไม่ต้องทำ)
มันก็วนลูป จนจบการทำงานนะครับ...

แล้วอย่างนี้...เราจะแก้ยังไงดีครับ...คิดไม่ออกเลย...


ช่วยทีครับ...ผม
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2010-11-22 11:00:25 By : พงศธร
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ERROR แบบนี้มันหมายความว่ายังไงครับ แปลกใจมาก แก้ก็ไม่ได้ VB 2008+SQL Server 2000
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 02
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่