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

System.Data.SqlClient.SqlException: "Ошибка преобразования значения varchar "DataGridViewTextBoxCell { ColumnIndex=0, Ro

20.11.2022, 12:45. Показов 1298. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Писал программу для курсовой, удаление и добавление записей в datagridview получилось сделать а вот СОХРАНЕНИЕ изменения какой либо записи в datagridview сделать не получилось, пишет якобы что первичный ключ не может преобразоваться в int.

Буду благодарен за помощь!

Метод сохранения изменения в бд:
Причем прошу заметить, первый цикл для сохранения удаления и ОН работает. Конвертировать я пробовал, вылезает другая ошибка.

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
private void UpdateRow()
        {
            database.openConnection();
 
 
            for(int index = 0; index < dataGridView1.Rows.Count; index++)
            {
                var rowState = (RowState)dataGridView1.Rows[index].Cells[5].Value;
                if (rowState == RowState.Existed)
                    continue;
                if (rowState == RowState.Deleted)
                {
                    var kod = Convert.ToInt32(dataGridView1.Rows[index].Cells[0].Value);
                    var deleteQuery = $"delete from Услуги where Код = {kod}";
                    var command = new SqlCommand(deleteQuery, database.getConnection());
                    command.ExecuteNonQuery();
                    
                }
                if(rowState == RowState.Modified)
                {
                    var kod = dataGridView1.Rows[index].Cells[0].ToString();
                    var nazvanie = dataGridView1.Rows[index].Cells[1].ToString();
                    var vid= dataGridView1.Rows[index].Cells[2].ToString();
                    var price = dataGridView1.Rows[index].Cells[3].ToString();
                    var opisanie = dataGridView1.Rows[index].Cells[4].ToString();
 
                    var changeQuery = $"update Услуги set Название = '{nazvanie}',Вид = '{vid}',[Цена (руб)] = '{price}',Описание = '{opisanie}' where Код ='" + kod + "'";
                    var command = new SqlCommand(changeQuery, database.getConnection());
                    command.ExecuteNonQuery();
                }
            }
            database.closeConnection();
        }
Метод самого изменения:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
private void Change()
        {
            var selectedRowIndex = dataGridView1.CurrentCell.RowIndex;
            var kod  = textBox1_kod.Text;
            var nazvanie = textBox3_nazvaniy.Text;
            var vid = textBox4_vid.Text;
            var opisanie =textBox6_opisanie.Text;
            int price;
 
            if (dataGridView1.Rows[selectedRowIndex].Cells[0].Value.ToString() != string.Empty)
            {
                if(int.TryParse(textBox5_price.Text, out price))
                {
                    dataGridView1.Rows[selectedRowIndex].SetValues(kod,nazvanie, vid, price, opisanie);
                    dataGridView1.Rows[selectedRowIndex].Cells[5].Value = RowState.Modified;
                }
                else
                {
                    MessageBox.Show("Цена должна иметь числовой формат!");
                }
            }
        }
Добавлено через 9 минут

System.Data.SqlClient.SqlException: "Ошибка преобразования значения varchar "DataGridViewTextBoxCell { ColumnIndex=0, RowIndex=8 }" в тип данных int."

Ругается на переменную "kod"

Вот полное описание ошибки
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.11.2022, 12:45
Ответы с готовыми решениями:

Ошибка System.Data.SqlClient.SqlException
Прошу помощи в таком простом тексте: использую dataGridView для работы с двумя таблицами из БД. Заполняется dataGridView нормально....

Не знаю в чем ошибка и как исправить System.Data.SqlClient.SqlException: "Must declare the scalar variable
Здравствуйте, Работаю с базой данных в windowsform. Пытаюсь написать кнопку обновления, но постоянно ругается уже не знаю что делать. ...

Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dll
При регистрации нового пользователя возникает ошибка

6
2287 / 1603 / 400
Регистрация: 26.06.2017
Сообщений: 4,748
Записей в блоге: 1
20.11.2022, 13:40
tiim20, сначала обязательно почитайте вот этот материал. Там доходчиво написано о разделении данных и интерфейса. Если бы у Вас к сетке был привязан DataSet, то с его помощью задача сохранения решается очень легко. В текущем варианте даже и рекомендовать что-то сложно, т.к. на каждую строку Вы создаёте свою команду. Даже, если и привести код в рабочее состояние, то его всё равно надо будет переделывать.
0
0 / 0 / 0
Регистрация: 20.11.2022
Сообщений: 3
20.11.2022, 13:48  [ТС]
Спасибо конечно, но у меня нету времени переделывать. Хотелось бы из текущего варианта что-то сделать
0
2287 / 1603 / 400
Регистрация: 26.06.2017
Сообщений: 4,748
Записей в блоге: 1
20.11.2022, 15:06
Тут проблема
C#
1
var kod = dataGridView1.Rows[index].Cells[0].ToString();
и в строке запроса тоже надо исправить
Просто сравните с этим
C#
1
var kod = Convert.ToInt32(dataGridView1.Rows[index].Cells[0].Value);
0
0 / 0 / 0
Регистрация: 20.11.2022
Сообщений: 3
20.11.2022, 20:37  [ТС]
я заменил но выдает теперь ошибку: System.Data.SqlClient.SqlException: "Произойдет усечение строковых или двоичных данных в столбце "Название" таблицы "fitnes-club.dbo.Услуги". Усеченное значение: "DataGridViewTextBoxCell { ColumnIndex=1, RowIndex=".
Выполнение данной инструкции было прервано."

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
private void UpdateRow()
        {
            database.openConnection();
            for(int index = 0; index < dataGridView1.Rows.Count; index++)
            {
                var rowState = (RowState)dataGridView1.Rows[index].Cells[5].Value;
                if (rowState == RowState.Existed)
                    continue;
                if (rowState == RowState.Deleted)
                {
                    var id = Convert.ToInt32(dataGridView1.Rows[index].Cells[0].Value);
                    var deleteQuery = $"delete from Услуги where Код = {id}";
                    var command = new SqlCommand(deleteQuery, database.getConnection());
                    command.ExecuteNonQuery();
                    
                }
                if(rowState == RowState.Modified)
                {
                    var id = Convert.ToInt32(dataGridView1.Rows[index].Cells[0].Value);
                    var nazvanie = dataGridView1.Rows[index].Cells[1].ToString();
                    var vid= dataGridView1.Rows[index].Cells[2].ToString();
                    var price = dataGridView1.Rows[index].Cells[3].ToString();
                    var opisanie = dataGridView1.Rows[index].Cells[4].ToString();
 
                    var changeQuery = $"update Услуги set Название = '{nazvanie}',Вид = '{vid}',[Цена (руб)] = '{price}',Описание = '{opisanie}' where Код ='" + id + "'";
                    var command = new SqlCommand(changeQuery, database.getConnection());
                    command.ExecuteNonQuery();
                }
            }
            database.closeConnection();
        }
Добавлено через 4 минуты
Все спасибо. Разобрался
0
 Аватар для Andrey-MSK
3349 / 2235 / 388
Регистрация: 14.08.2018
Сообщений: 7,557
Записей в блоге: 4
21.11.2022, 09:47
Цитата Сообщение от tiim20 Посмотреть сообщение
Все спасибо. Разобрался
Для Спасибо кнопки есть...
0
 Аватар для Kazbek17
1484 / 939 / 454
Регистрация: 06.02.2012
Сообщений: 2,868
21.11.2022, 11:15
Цитата Сообщение от tiim20 Посмотреть сообщение
Все спасибо. Разобрался
Разобрались вы, поясните другому. А то так каждому устанешь описывать такую же ситуацию.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.11.2022, 11:15
Помогаю со студенческими работами здесь

Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dll
Здраствуйте,помогите пожалуйста бедной девушке( При компилировании выдает ошибку : Необработанное исключение типа...

Как поймать исключение "System.Data.SqlClient.SqlException" ?
Как поймать исключение &quot;System.Data.SqlClient.SqlException&quot; ? У меня 3 формы (Номенклатура, Приход, Контрагент) все проходит через...

System.Data.SqlClient.SqlException: "Ошибка преобраз знач varchar "System.Func`1[System.String]" в тип данных int."
Делаю программу где есть кнопки &quot;Сохранение&quot;, &quot;Удаление, &quot;Изменения&quot; для datagridview, кнопка &quot;удаление&quot; строки из БД и...

System.Data.SqlClient.SqlException: "Ошибка при преобразовании типа данных varchar к float."
Когда ввожу данные в cena не цело численное возникает ошибка, с цело численными работает Код: using System; using...

Ошибка System.Data.SqlClient.SqlException неправильный синтаксис около конструкции
system.data.sqlclient.sqlexception неправильный синтаксис около конструкции string strIP1 = &quot;&quot;; System.Net.IPHostEntry...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru