Rabee Qabaha Ответов: 1

Отображение данных из базы данных в ссылку на объект listview ошибка


Всем привет,
Я использую UserControl, чтобы использовать его в панели в основной форме, но основной дизайн формы выходит из строя, когда я использую код ниже, чтобы показать данные в lostview.
и дайте мне эту ошибку
http://store1.up-00.com/2016-08/14726908191.png[^]
Ошибка:
Object reference not set to an instance of an object. 

Try
            Conn.Open()
            Dim dt As New DataTable
            Dim ds As New DataSet
            ds.Tables.Add(dt)
            Dim da As New SqlDataAdapter("select * from companies order by sdate DESC", Conn)
            da.Fill(dt)
            Dim myrow As DataRow
            For Each myrow In dt.Rows
                ListView1.Items.Add(myrow.Item(0)).ToString()
                ListView1.Items(ListView1.Items.Count - 1).SubItems.Add(myrow.Item(1))
                ListView1.Items(ListView1.Items.Count - 1).SubItems.Add(myrow.Item(2))
                ListView1.Items(ListView1.Items.Count - 1).SubItems.Add(myrow.Item(3))
                ListView1.Items(ListView1.Items.Count - 1).SubItems.Add(myrow.Item(4))
                ListView1.Items(ListView1.Items.Count - 1).SubItems.Add(myrow.Item(5))
            Next
            Conn.Close()

        Catch ex As SqlException
            MsgBox(ex.Message, MsgBoxStyle.Critical, "SQL Error")
            Conn.Close()
            'Catch ex As Exception
            'MsgBox(ex.Message, MsgBoxStyle.Critical, "General Error")
        End Try


Что я уже пробовал:

Поэтому я не знаю, что я могу сделать, чтобы решить эту проблему
мне нужна твоя помощь.

1 Ответов

Рейтинг:
6

OriginalGriff

Это одна из самых распространенных проблем, которые нам задают, и это также та, на которую мы меньше всего готовы ответить, но вы больше всего готовы ответить сами.

Позвольте мне просто объяснить, что означает ошибка: Вы попытались использовать переменную, свойство или возвращаемое значение метода, но оно содержит null - что означает, что в переменной нет экземпляра класса.
Это немного похоже на карман: у вас есть карман в рубашке, в котором вы держите ручку. Если вы сунете руку в карман и обнаружите, что там нет ручки, вы не сможете подписать свое имя на листе бумаги - и вы получите очень смешные взгляды, если попытаетесь! Пустой карман дает вам нулевое значение (здесь нет ручки!), поэтому вы не можете сделать ничего такого, что обычно делали бы, когда извлекли свою ручку. Почему он пуст? Вот в чем вопрос - может быть, вы забыли взять ручку, когда уходили из дома сегодня утром, или, возможно, вы оставили ручку в кармане вчерашней рубашки, когда снимали ее вчера вечером.

Мы не можем сказать, потому что нас там не было, и, что еще важнее, мы даже не можем видеть вашу рубашку, не говоря уже о том, что находится в кармане!

Вернемся к компьютерам, и вы каким - то образом сделали то же самое-и мы не можем увидеть ваш код, а тем более запустить его и узнать, что содержит null, когда это не должно быть.
Но вы можете - и Visual Studio поможет вам здесь. Запустите свою программу в отладчике, и когда она выйдет из строя, VS покажет вам строку, на которой она обнаружила проблему. Затем вы можете начать смотреть на различные его части, чтобы увидеть, какое значение равно null, и начать просматривать свой код, чтобы выяснить, почему. Поэтому поставьте точку останова в начале метода, содержащего строку ошибки, и снова запустите программу с самого начала. На этот раз VS остановится перед ошибкой и позволит вам изучить, что происходит, пройдя через код, глядя на ваши значения.

Но мы не можем этого сделать - у нас нет вашего кода, мы не знаем, как его использовать, если бы он у нас был, у нас нет ваших данных. Так что попробуйте - и посмотрите, сколько информации вы сможете узнать!

В данном конкретном случае это еще хуже, потому что проблема связана с конструктором для вашего элемента управления, поэтому его даже трудно отладить. Поэтому начните с удаления всего кода из вашего конструктора и медленно добавляйте его обратно, пока не появится элемент управления. Опять же, мы не можем сделать это для вас!


Rabee Qabaha

привет OriginalGriff спасибо за этот подробный ответ, на самом деле я знаю, откуда взялась ошибка, она исходит от метода showLV ( метод получения данных из sql server для отображения их в listview)
и если я удалил этот метод, все работает нормально, вопрос в том, как сделать этот код, чтобы избежать возврата нулевого значения .
спасибо вам

OriginalGriff

Поэтому используйте отладчик, чтобы выяснить, почему метод возвращает null - мы не можем сделать это за вас!

Rabee Qabaha

хорошо, спасибо, парень, я попробую еще раз