dyooshi Ответов: 2

Исключение Nullreferenceexception при использовании INSERT into для ввода данных в базу данных


Привет, у меня есть проблема, как указано выше, и я надеюсь, что смогу найти решение здесь. Так вот в чем ошибка:

Line 86: 
Line 87: 
Line 88:                 if (txtTempIdSubject.Text.Trim() == "")
Line 89:                 {
Line 90:                     lblAttention.Text = "Please enter complete data!";


Вот код, который имеет ошибку из файла .aspx.cs:

protected void dgSubject_ItemCommand(object sender, System.Web.UI.WebControls.DataGridCommandEventArgs e)
        {
            SubjectClass std = new SubjectClass();

            if (e.CommandName == "AddUser")
            {
                TextBox txtTempIdSubject = (TextBox)e.Item.Cells[0].FindControl("txtSubjectID");
                TextBox txtTempNameSubject = (TextBox)e.Item.Cells[1].FindControl("txtSubjectName");
                TextBox txtTempModifiedBy = (TextBox)e.Item.Cells[2].FindControl("txtModifiedBy");
                TextBox txtTempModifiedOn = (TextBox)e.Item.Cells[3].FindControl("txtModifiedOn");



                if (txtTempIdSubject.Text.Trim() == "" )-----> here is the error
                {
                    lblAttention.Text = "Please enter complete data!"; 
                }
                else
                {
                    if (std.AddSubject(txtTempIdSubject.Text,txtTempNameSubject.Text, txtTempModifiedBy.Text, txtTempModifiedOn.Text) == false)
                    {
                        lblAttention.Text = " *Data addition failed!";
                    }
                    else
                    {
                        Server.Transfer("Subject.aspx");
                    }
                }
            }


а вот и класс:

public bool AddSubject(string idSubject,string nameSubject, string modifiedBy, string modifiedOn)
        {
            try
            {
             if (this.SetIdSubject(Convert.ToInt32(idSubject)) && this.SetNameSubject(nameSubject) && this.SetModifiedBy(modifiedBy) && this.SetModifiedOn(System.DateTime.Now))
                {
                    DatabaseManager db = new DatabaseManager();
                    cmd = new SqlCommand();
                    cmd.CommandText = "INSERT INTO [dbo].[Subjects]" +
                        "(SubjectID,SubjectName, UpdatedBy, UpdatedOn)" +
                        "VALUES" +
                        "(@P1, @P2, @P3,@P4)";
                    cmd.Parameters.AddWithValue("@P1", this.GetIdSubject());
                    cmd.Parameters.AddWithValue("@P2", this.GetNameSubject());
                    cmd.Parameters.AddWithValue("@P2", this.GetModifiedBy());
                    cmd.Parameters.AddWithValue("@P4", System.DateTime.Now.ToString());
                    db.ExecuteNonQuery(cmd);
                    return true;
                }
                else
                {
                    return false;
                }
            }
            catch
            {
                return false;
            }
        }


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

Я изменил все данные таблицы Subjects на not null, потому что обнаружил, что одно из решений говорит о том, что мне нужно убедиться, что данные не находятся в NULL, но это все равно дает эту ошибку.

ZurdoDev

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

2 Ответов

Рейтинг:
1

W∴ Balboos, GHB

Цитата:
Я изменил все данные таблицы Subjects на not null, потому что обнаружил, что одно из решений говорит о том, что мне нужно убедиться, что данные не находятся в NULL, но это все равно дает эту ошибку.
Это звучит так, как будто вы копируете решения, но на самом деле не имеете ни малейшего представления о том, что вы делаете.

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

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


Рейтинг:
1

OriginalGriff

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

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

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

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

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