powered by simpleCommunicator - 2.0.51     © 2025 Programmizd 02
Форумы / ADO.NET, LINQ, Entity Framework, NHibernate, DAL, ORM [игнор отключен] [закрыт для гостей] / Ссылка на объект не указывает на экземпляр объекта.
5 сообщений из 5, страница 1 из 1
Ссылка на объект не указывает на экземпляр объекта.
    #38273775
Alodie
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Заранее извиняюсь за глупый вопрос, но не могу исправить, клиент-серверное приложение
textBox привязан к DataGridView и при попытке обновить или добавить запись в этой строке возникает исключение.
Только начала все это изучать, делаю по примерам с форумов и книг.
Что дописать, чтобы программа работала?
данные к datagridview соответственно привязаны не через код.

Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
namespace WindowsFormsApplication1
{
    public partial class Form9 : Form
    {
        string sqlcs;
        SqlConnection conn = new SqlConnection();
        
        public Form9()
        {
           InitializeComponent();
           sqlcs = @"Data Source = MICROSOFT-PC; Initial Catalog = ИЗДАТЕЛЬСТВО.MDF; Integrated Security=True";
         }

      

        private void Form9_Load(object sender, EventArgs e)
        {
           
            //TODO: данная строка кода позволяет загрузить данные в таблицу "_ИЗДАТЕЛЬСТВО_MDFDataSet2.Должности". При необходимости она может быть перемещена или удалена.
            this.должностиTableAdapter.Fill(this._ИЗДАТЕЛЬСТВО_MDFDataSet2.Должности); 
        }

        private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
        {
         
           
        }


        private void button3_Click(object sender, EventArgs e) //добавление
        {
          if (textBox2.Text != dataGridView1.CurrentRow.Cells[0].Value.ToString())
          if (textBox2.Text != "")
            {

                try
                {

                        string D = Convert.ToString(this.textBox2.Text);
                        conn.ConnectionString = sqlcs;
                        conn.Open();
                        SqlCommand myCommand = conn.CreateCommand();
                        myCommand.CommandText = "INSERT INTO " +
                        "Должности (Название)" +
                        "VALUES (@D)";
                        myCommand.Parameters.Add("@D", SqlDbType.NChar);
                        myCommand.Parameters["@D"].Value = D;
                        
                        int UspeshnoeIzmenenie = myCommand.ExecuteNonQuery();
                        if (UspeshnoeIzmenenie != 0)
                        {
                            MessageBox.Show("Изменения внесены", "Изменение записи");
                        }
                        else
                        {
                            MessageBox.Show("Не удалось внести изменения", "Изменение записи");
                        }
                        должностиTableAdapter.Fill(_ИЗДАТЕЛЬСТВО_MDFDataSet2.Должности);
                       
                    }
                
                catch (Exception ex)
                {

                    MessageBox.Show(ex.ToString());
                }
                finally
                {
                    
                    conn.Close();
                }
            
            }
            else
            {
                MessageBox.Show("Заполните все поля", "Обновление записи");
            }
           else
          {
              MessageBox.Show("Должность уже есть в базе!", "Обновление записи");
           }
          
        }

       

        private void dataGridView1_SelectionChanged(object sender, EventArgs e)
        {
  
  textBox2.Text = dataGridView1.CurrentRow.Cells[0].Value.ToString();   // в данной строке возникает исключение.
     
        }

        private void dataGridView1_CellContentClick_1(object sender, DataGridViewCellEventArgs e)
        {

        }
   
    }
}
...
Рейтинг: 0 / 0
Ссылка на объект не указывает на экземпляр объекта.
    #38276519
Фотография pation
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Alodie,

а какое значение в текущей строке в ячейке 0?
...
Рейтинг: 0 / 0
Ссылка на объект не указывает на экземпляр объекта.
    #38277165
Narvasadata
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
pation,
есть инфа, что событие SelectionChanged вызывается раньше чем DataGridView.DataSource = DataSet.Tables[0], поэтому при FormLoad -> SelectionChanged, валится т.к. нет строк в гриде

Была такая трабла, решил так

Код: c#
1.
2.
3.
4.
this.dataGridView1.SelectionChanged -= new System.EventHandler(this.dataGridView1_SelectionChanged);
            dataGridView1.DataSource = ds.Tables[0];
            dataGridView1.Rows[0].Selected = false;
            this.dataGridView1.SelectionChanged += new System.EventHandler(this.dataGridView1_SelectionChanged);



может не кошерно хз)
...
Рейтинг: 0 / 0
Ссылка на объект не указывает на экземпляр объекта.
    #38278976
Alodie
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Narvasadata,

спасибо, так работает)
А вы не подскажете, как теперь при нажатии на кнопку вызвать dataGridView_selectionChanged и соответственно заполнение всех полей?
...
Рейтинг: 0 / 0
Ссылка на объект не указывает на экземпляр объекта.
    #38280840
Narvasadata
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Alodie,

Код: c#
1.
2.
3.
4.
private void button1_Click(object sender, EventArgs e)
        {
            dataGridView1_SelectionChanged(sender, e);
        }
...
Рейтинг: 0 / 0
5 сообщений из 5, страница 1 из 1
Форумы / ADO.NET, LINQ, Entity Framework, NHibernate, DAL, ORM [игнор отключен] [закрыт для гостей] / Ссылка на объект не указывает на экземпляр объекта.
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]