Member 12735615 Ответов: 2

Ссылка на объект не установлена на экземпляр объекта. Исключение, попытка сделать строку только для чтения после вставки


я получаю это исключение :
**

Ссылка на объект не установлена на экземпляр объекта.
**

у меня есть datagridview, который я использую , я смог просмотреть данные из представления datagrid в новую c# winform, теперь у меня есть что-то, что бросает мне вызов.

новая winform получает информацию из представления datagrid, я установил модификаторы в public, так что она работает нормально, теперь она собирает информацию и сохраняет ее в базе данных. Теперь возникла проблема, когда я хотел сделать его только для чтения, чтобы после того, как информация была сохранена, она не могла быть удалена или даже изменена.

ПС Вот чего я хочу добиться, если информация была введена в базу данных, то она должна сохраниться внутри базы данных из новой созданной всплывающей формы. Затем строка, из которой я выбрал информацию из формы ApproveAppointment, должна быть прочитана только для чтения и не может быть выбрана снова

Мой код выглядит так

private void button2_Click(object sender, EventArgs e)
{
    DialogResult result = MessageBox.Show("You are about to Approve an Appointment. If approved, the information will be saved to the Visitor Appointment Database " + Environment.NewLine + " Are You sure You want to Approve ?", "New Message!",MessageBoxButtons.YesNo, MessageBoxIcon.Question);

    if (result == DialogResult.Yes)
    {

        try
        {
            string constring = ConfigurationManager.ConnectionStrings["MySQLDatabaseConnection"].ConnectionString;
            using (MySqlConnection con = new MySqlConnection(constring))
            {
                con.Open();
                string sql = "insert into vms_db.final_appointments (visit_date, visitor_name, visit_address,visit_city,signin_time,vehicle_number,organization,visit_type,reason,id_type,person_visit,img) values (@visit_date, @visitor_name, @visit_address,@visit_city,@signin_time,@vehicle_number,@organization,@visit_type,@reason,@id_type,@person_visit,@img)";
                using (MySqlCommand cmd = new MySqlCommand(sql, con))
                {
                    MemoryStream ms = new MemoryStream();
                    pictureBox.Image.Save(ms, pictureBox.Image.RawFormat);
                    byte[] img = ms.ToArray();
                    cmd.Parameters.AddWithValue("@visit_date", visit_date.Text);
                    cmd.Parameters.AddWithValue("@visitor_name", visitor_name.Text);
                    cmd.Parameters.AddWithValue("@visit_address", address.Text);
                    cmd.Parameters.AddWithValue("@visit_city", city.Text);
                    cmd.Parameters.AddWithValue("@signin_time", sign_intime.Text);
                    cmd.Parameters.AddWithValue("@vehicle_number", vehicle_number.Text);
                    cmd.Parameters.AddWithValue("@organization", organization.Text);
                    cmd.Parameters.AddWithValue("@visit_type", visit_type.Text);
                    cmd.Parameters.AddWithValue("@reason", reason.Text);
                    cmd.Parameters.AddWithValue("@id_type", id_type.Text);
                    cmd.Parameters.AddWithValue("@person_visit", person_visit.Text);
                    cmd.Parameters.AddWithValue("@img", img);
                    cmd.ExecuteNonQuery();
                    MessageBox.Show("Final Appointment Created " + Environment.NewLine + "You may now close this Window", "New Message", MessageBoxButtons.OK, MessageBoxIcon.Information);
                   // Close();

                    ApproveAppointMents app = new ApproveAppointMents();
                    app.dataGridView1.CurrentRow.ReadOnly = false;
                }
            }
        }

        catch (Exception ex)
        {
            MessageBox.Show(ex.ToString());
        }
    }
    else
    {
        MessageBox.Show("No Information found." + Environment.NewLine + "Please Check and Try again", "Message!", MessageBoxButtons.OK, MessageBoxIcon.Information);
    }
}


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

я использовал
app.dataGridView1.CurrentRow.ReadOnly
и это вызвало исключение:
Triggers Object Reference not set to instance of an object 

F-ES Sitecore

Либо "приложения" равно null, "приложение.dataGridView1" имеет значение null, или "приложение.dataGridView1.CurrentRow" имеет значение null. Используйте отладчик, чтобы выяснить, что именно, и идите оттуда.

2 Ответов

Рейтинг:
2

OriginalGriff

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

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

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

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

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


Рейтинг:
14

Karthik_Mahalingam

Цитата:
Ссылка на объект не установлена на экземпляр объекта

Как правило, вы получаете эту ошибку при попытке получить доступ к members в object который null, Пожалуйста, подтвердите для null значения перед доступом к членам, но вам придется проверить, почему object is null на первом месте.

ApproveAppointMents app = new ApproveAppointMents();
           if (app.dataGridView1 != null)
               if (app.dataGridView1.CurrentRow != null)
                   app.dataGridView1.CurrentRow.ReadOnly = false;


Member 12735615

Спасибо, здесь нет исключений, но я хочу установить цвет на серый или красный, чтобы показать, что это была выбранная строка. я использую этот DefaultCellStyle.SelectionBackColor и это не работает. что же мне делать?

Karthik_Mahalingam

пробовать
.DefaultCellStyle.BackColor = Цвет.Красный;

Member 12735615

я сделал это вот так

ApproveAppointMents app = новые ApproveAppointMents();
если (прилож.dataGridView1 != нуль)
{
если (прилож.dataGridView1.CurrentRow != нуль)
{
приложение.dataGridView1.CurrentRow.Толькочтение = истина;
приложение.dataGridView1.DefaultCellStyle.SelectionBackColor = Color. Red;
}
}

Все равно не получится.

Karthik_Mahalingam

Задний цвет

Member 12735615

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