Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
1 / 1 / 0
Регистрация: 05.12.2016
Сообщений: 178

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

09.05.2017, 22:36. Показов 1733. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Народ прошу помочь есть хранимая процедура с вызовом параметра сам по себе работает но в программке выдает ошибку (Ссылка на объект не указывает на экземпляр объекта.) Что делать?

C#
1
2
3
4
5
6
7
8
9
10
for (int i = 0; i < dataGridViewEmployee.RowCount; i++)
            {
                cmd.CommandText = "EXECUTE HPGiveNamePost @Должности, @Название OUTPUT";
                cmd.Parameters.Clear();
                cmd.Parameters.Add("@Должности", SqlDbType.Int).Value = dataGridViewEmployee[1, i].Value.ToString();
                cmd.Parameters.Add(new SqlParameter("@Название", SqlDbType.VarChar, 30));
                cmd.Parameters["@Название"].Direction = ParameterDirection.Output;
                cmd.ExecuteNonQuery();
                dataGridViewEmployee[1, i].Value = cmd.Parameters["@Название"].Value.ToString().Trim();
            }
часть кода

Добавлено через 5 минут
То есть смысл я ошибки понимаю здесь значение Null передается. Но никак не могу понять как исправить
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.05.2017, 22:36
Ответы с готовыми решениями:

Ссылка на объект не указывает на экземпляр объекта
Не могу записать данные из dataGridView пишет &quot;Ссылка на объект не указывает на экземпляр объекта.&quot; using System; using...

Ссылка на объект не указывает на экземпляр объекта
при нажатии на кнопку выдает ошибку Ссылка на объект не указывает на экземпляр объекта. ошибка в строке 222 learn = x; не могу...

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

8
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
09.05.2017, 22:36
Думаю, что нужно инициализировать поле cmd. Ведь ты не сказала, на какой именно строке ругается.
C#
1
cmd = new SqlCommand();
0
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
09.05.2017, 22:41
И еще, если работаете с msSql - то учитесь отправлять xml файлы вместо того, чтобы в цикле делать отправку. Сервер быстрее сообразит, чем Вы будете по кусочку дергать его, да и нагрузка на сеть поменьше будет.
0
1 / 1 / 0
Регистрация: 05.12.2016
Сообщений: 178
09.05.2017, 22:51  [ТС]
ViterAlex,
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
 public partial class FormViewEmployee : Form
    {
        public FormViewEmployee()
        {
            SqlConnection conn = new SqlConnection(
                   "Data Source=PC-ANTON\\SQLEXPRESS;" + "Initial Catalog=Аптека;" + "Integrated Security=True");
            conn.Open();
            SqlCommand cmd = conn.CreateCommand();
            InitializeComponent();
            cmd.CommandText = "SELECT * FROM Сотрудники";
            SqlDataReader reader = cmd.ExecuteReader();
            while (reader.Read())
            {
                DataGridViewCell id = new DataGridViewTextBoxCell();
                DataGridViewCell post = new DataGridViewTextBoxCell();
                DataGridViewCell branch = new DataGridViewTextBoxCell();
                DataGridViewCell fio = new DataGridViewTextBoxCell();
                DataGridViewCell address = new DataGridViewTextBoxCell();
                DataGridViewCell telephone = new DataGridViewTextBoxCell();
                DataGridViewCell login = new DataGridViewTextBoxCell();
                DataGridViewCell password = new DataGridViewTextBoxCell();
 
                DataGridViewRow row = new DataGridViewRow();
                id.Value = reader["ID_Сотрудники"].ToString();
                post.Value = reader["Должности"].ToString();
                branch.Value = reader["Филиалы"].ToString();
                fio.Value = reader["ФИО"].ToString().Trim();
                address.Value = reader["Адрес"].ToString().Trim();
                telephone.Value = reader["Телефон"].ToString();
                login.Value = "";
                password.Value = "";
                row.Cells.AddRange(id, post, branch, fio, address, telephone, login, password);
                dataGridViewEmployee.Rows.Add(row);
            }
            reader.Close();
 
            for (int i = 0; i < dataGridViewEmployee.RowCount; i++)
            {
                cmd.CommandText = "EXECUTE HPGiveNamePost @Должности, @Название OUTPUT";
                cmd.Parameters.Clear();
                cmd.Parameters.Add("@Должности", SqlDbType.Int).Value = dataGridViewEmployee[1, i].Value.ToString();
                cmd.Parameters.Add(new SqlParameter("@Название", SqlDbType.VarChar, 30));
                cmd.Parameters["@Название"].Direction = ParameterDirection.Output;
                cmd.ExecuteNonQuery();
                dataGridViewEmployee[1, i].Value = cmd.Parameters["@Название"].Value.ToString().Trim();
            }
 
            for (int i = 0; i < dataGridViewEmployee.RowCount; i++)
            {
                cmd.CommandText = "EXECUTE HPGiveNameBranch @Филиалы, @Название OUTPUT";
                cmd.Parameters.Clear();
                cmd.Parameters.Add("@Филиалы", SqlDbType.Int).Value = dataGridViewEmployee[2, i].Value.ToString();
                cmd.Parameters.Add(new SqlParameter("@Название", SqlDbType.VarChar, 30));
                cmd.Parameters["@Название"].Direction = ParameterDirection.Output;
                cmd.ExecuteNonQuery();
                dataGridViewEmployee[2, i].Value = cmd.Parameters["@Название"].Value.ToString().Trim();
            }
 
            cmd.CommandText = "SELECT * FROM ПривилегированныеСотрудники";
            reader = cmd.ExecuteReader();
            int j = 0;
            while (reader.Read())
            {
                string id = reader["ID_Сотрудники"].ToString();
                string login = reader["Логин"].ToString().Trim();
                string password = reader["Пароль"].ToString().Trim();
                for (int i = 0; i < dataGridViewEmployee.RowCount; i++)
                {
                    if (dataGridViewEmployee[0, i].Value.ToString().Trim().CompareTo(id.Trim()) == 0)
                    {
                        dataGridViewEmployee[6, i].Value = login;
                        dataGridViewEmployee[7, i].Value = password;
                        j = i + 1;
                        break;
                    }
                }
            }
            reader.Close();
Я инициализировать поле cmd ругается на строчку
C#
1
cmd.Parameters.Add("@Должности", SqlDbType.Int).Value = dataGridViewEmployee[1, i].Value.ToString();

Добавлено через 54 секунды
hoolygan, Просто мй вариант пока для меня лучше в понимании.
0
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
09.05.2017, 22:58
Цитата Сообщение от 99Екатерина99 Посмотреть сообщение
cmd ругается на строчку
Видимо, ячейка пустая.
0
1 / 1 / 0
Регистрация: 05.12.2016
Сообщений: 178
09.05.2017, 23:02  [ТС]
ViterAlex, Да вот в том то и прикол в базе таблица заполнена, все ячейки заполнены. Суть в чем этой процедур хочу что бы вместо int числа ID должности в гриде отображалось название этой должности а не ID. Думала получится через выходной параметр, но не выходит
0
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
09.05.2017, 23:10
Попробуйте вместо стринга привести к инту входящий параметр. Типа tryparse. Может он не воспринимает вашу строчку.
0
1 / 1 / 0
Регистрация: 05.12.2016
Сообщений: 178
09.05.2017, 23:12  [ТС]
hoolygan, Эм а как не подскажите ?
0
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
09.05.2017, 23:20
Я не уверен, что это поможет, но можно попробовать.
Вы при указанииValue испотзуете ToString () из грида. Оберните это дела в TryParse.ToInt32(). Мало того, а точно все айдишки присутствуют? Нету нигде DbNull.Value? Плпробвйте вынести в отдельную переменную айдишки до построения параметра для cmd.а потом эту же переменную подсововать в параметр, заодно и посмотрите на значение. Или воспользуйтесь дебагером, и смотрите, что в параметр лезет. Блин, с телефона вообще неудобно писать...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.05.2017, 23:20
Помогаю со студенческими работами здесь

Ссылка на объект не указывает на экземпляр объекта
В main есть данный код: rb = new RadioButton; for (int i = 0; i &lt; rb.Length; i++) { rb...

Ссылка на объект не указывает на экземпляр объекта
Всем привет! Мне необходимо написать следующее приложение: на форме один по периметру бегает Label и плавно меняет свой цвет. На второй...

Ссылка на объект не указывает на экземпляр объекта
private List&lt;Goods&gt; listOfObj = new List&lt;Goods&gt;(); private Dictionary&lt;TreeNode, Type&gt; goodses; private...

Ссылка на объект не указывает на экземпляр объекта
Не понимаю в чём ошибка в коде. Выкидывает исключение и в нём то, что в названии. Указывает на 65 и 223 строки. P.S. Учусь ещё, не могу всё...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru