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

При изменение данных в столбце выдаёт ошибку и не изменяет сами данные

24.05.2022, 09:33. Показов 356. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Столкнулся с такой вот проблемой. При редактировании данных в таблице появляется вот ошибка System.Data.OleDb.OleDbException: "Data type mismatch in criteria expression." и сами данные не меняются. Подскажите пожалуйста в чём проблема. Вот код:
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
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.OleDb;
 
namespace Учёт_поступлений_готовой_продукции_на_склад
{
    public partial class Productiya : Form
    {
        public static string connectString = "Provider = Microsoft.ACE.OLEDB.12.0;Data Source = Склад с бумажной продукцией.accdb";
        private OleDbConnection myConnection;
        public Productiya()
        {
            InitializeComponent();
            myConnection = new OleDbConnection(connectString);
            myConnection.Open();
        }
 
        private void Form5_Load(object sender, EventArgs e)
        {
            // TODO: данная строка кода позволяет загрузить данные в таблицу "склад_с_бумажной_продукциейDataSet3.Продукция". При необходимости она может быть перемещена или удалена.
            this.продукцияTableAdapter.Fill(this.склад_с_бумажной_продукциейDataSet3.Продукция);
 
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            this.Close();
        }
 
        private void добавитьЗаписьToolStripMenuItem_Click(object sender, EventArgs e)
        {
            ProductiyaDob af = new ProductiyaDob();
            af.Owner = this;
            af.Show();
        }
 
        private void удалитьЗаписьToolStripMenuItem_Click(object sender, EventArgs e)
        {
            int i = dataGridView1.CurrentRow.Index;
            string s;
            s = "\n Наименование: " + Convert.ToString(dataGridView1[1, i].Value) +
                "\n ЕдИзмер: " + Convert.ToString(dataGridView1[2, i].Value) +
                "\n Цена: " + Convert.ToString(dataGridView1[3, i].Value) + "\n";
            if (DialogResult.Yes == MessageBox.Show("Вы уверены, что хотите удалить запись " + s + "?",
                "Подтверждение", MessageBoxButtons.YesNo, MessageBoxIcon.Exclamation))
            {
                if ((dataGridView1.CurrentRow.Index >= 0) && (dataGridView1.CurrentRow.Index < dataGridView1.RowCount - 1))
                    dataGridView1.Rows.RemoveAt(dataGridView1.CurrentRow.Index);
            }
        }
 
        private void button2_Click(object sender, EventArgs e)
        {
            продукцияTableAdapter.Update(склад_с_бумажной_продукциейDataSet3.Продукция);
        }
        
        //Редактирование записи
        private void button3_Click_1(object sender, EventArgs e)
        {
            string query = "UPDATE Продукция SET Наименование=@Наименование, ЕдИзмер=@ЕдИзмер, Цена=@Цена WHERE КодПродукции=@КодПродукции";
            OleDbCommand cmd = new OleDbCommand(query, myConnection);
 
            cmd.Parameters.AddWithValue("@КодПродукции", textBox1.Text);
            cmd.Parameters.AddWithValue("@Наименование", textBox2.Text);
            cmd.Parameters.AddWithValue("@ЕдИзмер", textBox3.Text);
            cmd.Parameters.AddWithValue("@Цена", textBox4.Text);
            cmd.ExecuteNonQuery();
            MessageBox.Show("Запись была обновлена", "Обновление данных", MessageBoxButtons.OK, MessageBoxIcon.Information);
            this.продукцияTableAdapter.Fill(this.склад_с_бумажной_продукциейDataSet3.Продукция);
        }
 
        private void dataGridView1_CellEnter_1(object sender, DataGridViewCellEventArgs e)
        {
            textBox1.Text = dataGridView1.CurrentRow.Cells[0].Value.ToString();
            textBox2.Text = dataGridView1.CurrentRow.Cells[1].Value.ToString();
            textBox3.Text = dataGridView1.CurrentRow.Cells[2].Value.ToString();
            textBox4.Text = dataGridView1.CurrentRow.Cells[3].Value.ToString();
        }
    }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.05.2022, 09:33
Ответы с готовыми решениями:

При изменение данных в столбце выдает ошибку
Привет! Столкнился с такой проблемой. В datagridview есть 3 столбца ID, INFO, VALUE. Если при редактирование хочу поменять в столбце...

При попытке загрузить данные из файла в базу данных сервера выдает ошибку -401 Unauthorize
Здравствуйте! Проект asp.net core 3.1, mvc. Пытаюсь загрузить данные из файла в базу данных сервера, с помощью POST-запроса с...

Почему программа выдает ошибку? Можно подобрать входные данные при которых программа выдает ошибку
Гарри в печали: вот уже девять лет как он не достает свою волшебную палочку на камеру. Но случилось чудо! Продюсеры дали добро на съемку...

1
Эксперт .NET
 Аватар для Usaga
14305 / 9389 / 1355
Регистрация: 21.01.2016
Сообщений: 35,401
24.05.2022, 10:22
DM-NJK, вы пробовали текст ошибки прочитать? Там ясно сказано, что не так.

Кликните здесь для просмотра всего текста

Цитата Сообщение от DM-NJK Посмотреть сообщение
WHERE КодПродукции=@КодПродукции";
Цитата Сообщение от DM-NJK Посмотреть сообщение
cmd.Parameters.AddWithValue("@КодПродукц ии", textBox1.Text);
Какого типа поле КодПродукции в базе, и какой тип вы в параметры передали?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.05.2022, 10:22
Помогаю со студенческими работами здесь

Код PHP не берёт данные из базы данных, при авторизации всегда выдаёт прописанную ошибку "Неверный логин или пароль"
&lt;head&gt; &lt;meta charset=&quot;UTF-8&quot;&gt; &lt;title&gt;QestBar&lt;/title&gt; &lt;/head&gt; &lt;?php require...

При выводе данных в таблице в jsp, шапка таблицы выводится, а сами данные нет
Передача списка в jsp: @Controller @RequestMapping(&quot;/&quot;) public class EmployeeControllers { @Autowired ...

При попытке сохранить данные Access выдает ошибку аргумента
При попытке сохранить данные выдает ошибку аргумена. Если я сожму базу то 3-4 записи проходят а потом такая же канитель. База весит 2...

Необходимо вывести нечётные элементы (сами числа) из массива. Выдаёт ошибку
Необходимо вывести нечётные элементы (сами числа) из массива. Выдаёт ошибку Unit1.pas(20): Operator not applicable to this operand...

При попытке записать данные из БД в таблицу Excel прога выдает ошибку
private void button1_Click_1(object sender, EventArgs e) { Microsoft.Office.Interop.Excel.Application ObjExcel =...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru