Paolo Tansengco Ответов: 2

Нужна помощь по моему datareader в visual studio 2015


Мой код работал нормально до тех пор, пока я не добавил параметры. С тех пор я получаю эту ошибку:

Необработанное исключение типа "System.NullReferenceException" произошло в NewMonitoringSystem.exe

Дополнительная информация: ссылка на объект не установлена на экземпляр объекта.


Мне нужна помощь в том, как исправить эту ошибку. Большое спасибо. Вот мой код: Ошибка в строке 10 настоящего Кодекса

Private Sub btnLogin_Click(sender As Object, e As EventArgs) Handles btnLogin.Click
    frmMainMenu.Height = 720
    frmMainMenu.Width = 950
    Dim numID As Integer = 2
    cmd.Connection = cn
    cn.Open()
    cmd.CommandText = "SELECT ID, username, password FROM tblUsers WHERE username = @username and password = @password"
    cmd.Parameters.Add(New SqlClient.SqlParameter("@username", SqlDbType.VarChar, 20)).Value = txtUsername.Text
    cmd.Parameters.Add(New SqlClient.SqlParameter("@password", SqlDbType.VarChar, 20)).Value = txtPassword.Text
    If dr.HasRows Then
        dr.Read()
        If dr("ID") = numID Then
            Me.Hide()
            frmMainMenu.lblAccessLevel.Text = "Admin"
            frmMainMenu.Show()
        Else
            Me.Hide()
            frmMainMenu.lblAccessLevel.Text = "User"
            frmMainMenu.TSMOffertory.Enabled = False
            frmMainMenu.TSMOffertory.Visible = False
            frmMainMenu.Show()
        End If
    Else
        MsgBox("Invalid Credentials", MsgBoxStyle.Exclamation, "Invalid LogIn")
    End If
    cn.Close()
End Sub


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

Я ничего не пробовал, потому что не знаю, что делать.

[no name]

Что значит-не знаешь, что делать? Ошибка означает точно то же самое, что и все остальные, кто ее получил, и вы исправляете ее точно так же, как это сделали все остальные в мире. Узнайте, как провести некоторые исследования и научиться использовать свой отладчик.

2 Ответов

Рейтинг:
8

Paolo Tansengco

dr = cmd.ExecuteReader


Это исправило код.


Рейтинг:
17

OriginalGriff

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

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

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

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

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