С Новым годом! Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/26: Рейтинг темы: голосов - 26, средняя оценка - 4.65
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1

Исключение при выполнении запроса к базе данных command.ExecuteNonQuery

13.08.2012, 11:27. Показов 4911. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
    public sealed class DataAccessLayer
    {
        string _connectionString = @"Data Source=CASPER-PC\SQLEXPRESS;Initial Catalog=BankCredits;Integrated Security=True;";
 
        internal bool SaveNewPayment(Guid id, Guid creditId, decimal amount, DateTime paymentDate)
        {
            bool successTransaction = false;
 
            using (SqlConnection connection = new SqlConnection(_connectionString))
            {
                connection.Open();
                SqlTransaction transaction = connection.BeginTransaction();
                SqlCommand command = connection.CreateCommand();
                command.Transaction = transaction;
 
                try
                {
                    string queryInsert = string.Format("INSERT INTO Payments (ID, CreditID, Amount, PaymentDate) " +
                        "VALUES ('{0}', '{1}', '{2}', '{3}')", id, creditId, amount, paymentDate);
                    command.CommandText = queryInsert;
                    command.ExecuteNonQuery();
 
                    string queryUpdate = string.Format("UPDATE Credits SET Balance = (Balance - {0}) WHERE ID = '{1}'",
                        amount, creditId);
                    command.CommandText = queryUpdate;
                    command.ExecuteNonQuery();
                    command.Transaction.Commit(); //После вызова все изменения приняты, транзакция выполнена
                    successTransaction = true;
                }
                catch (Exception)
                {
                    command.Transaction.Rollback();
                }
            }
 
            return successTransaction;
        }
    }
Если значение платежа любое целое число, то проблем нет, если значение платежа (переменная amount), например 1000,5, то вылетает исключение на строке 22 (command.ExecuteNonQuery())
SqlException: Ошибка при преобразовании типа данных varchar к numeric.


Вот скриншот таблицы:


Я что-то не пойму, что там к чему преобразовывается? Где там varchar и что за numeric? Вообще кто знает, что вызывает данное исключение? Может в таблице что-то не так? Какую ещё информацию приложить, чтобы стало яснее?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.08.2012, 11:27
Ответы с готовыми решениями:

При выполнении запроса UPDATE возникает ошибка ORA-00933: SQL command not properly ended для таблицы с составным ключом
Эй, ребята, я пытаюсь обновить свою таблицу следующей частью кода: private void button4_Click(object sender, EventArgs e) ...

ошибка при выполнении SqlCeCommand.ExecuteNonQuery()
таблица: id(uniqueidemtifier),name(ntextl),namel(ntext),date(datetime) string constr = "Data Source=bd.sdf;Persist Security...

Синтаксическая ошибка при выполнении команды БД ExecuteNonQuery
Вот такая ошибка вылетает, как исправить?

2
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
13.08.2012, 11:45  [ТС]
Упс, не в том разделе создал тему случайно.

Добавлено через 17 минут
А всё решил проблему, создаём текстовую переменную:
C#
1
string paymentAmount = amount.ToString(CultureInfo.InvariantCulture.NumberFormat);
И далее в запрос вместо самого числа amount подставляем уже конвертированное его значение. Короче проблема была в запятой, а должна быть точка (1000,5 была, а надо 1000.5).
0
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
14.08.2012, 16:48  [ТС]
Что ж мне никто не сказал, что это не верный подход к отправке запросов вообще . Запрос оказывается могут перехватить и вставить туда ещё какую-то команду, а с параметрами это как мне сказали сделать нельзя (вообще сомнения насчёт этой информации). Хотя кто его знает.

Переписал с параметрами:
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
        internal bool SaveNewPayment(Guid id, Guid creditId, decimal amount, DateTime paymentDate)
        {
            bool transactionSuccess = false;
 
            using (SqlConnection connection = new SqlConnection(_connectionString))
            {
                connection.Open();
                SqlTransaction transaction = connection.BeginTransaction();
                SqlCommand command = connection.CreateCommand();
                command.Transaction = transaction;
 
                try
                {
                    command.Parameters.Add(new SqlParameter("@ID", System.Data.SqlDbType.UniqueIdentifier) { Value = id });
                    command.Parameters.Add(new SqlParameter("@CreditID", System.Data.SqlDbType.UniqueIdentifier) { Value = creditId });
                    command.Parameters.Add(new SqlParameter("@Amount", System.Data.SqlDbType.Decimal) { Value = amount });
                    command.Parameters.Add(new SqlParameter("@PaymentDate", System.Data.SqlDbType.DateTime) { Value = paymentDate });
                    command.CommandText = "INSERT INTO Payments (ID, CreditID, Amount, PaymentDate) " +
                                 "VALUES (@ID, @CreditID, @Amount, @PaymentDate);" +
                                 "UPDATE Credits SET Balance = (Balance - @Amount) WHERE ID = @CreditID";
                    command.ExecuteNonQuery();
 
                    command.Transaction.Commit(); //После вызова все изменения приняты, транзакция выполнена
                    transactionSuccess = true;
                }
                catch (Exception)
                {
                    command.Transaction.Rollback();
                }
                finally
                {
                    command.Dispose();
                }
            }
 
            return transactionSuccess;
        }
Добавлено через 3 минуты
Да и вообще можно было всё одним запросом отправить (как я и сделал). Правда не знаю имеет ли смысл тут тогда транзакция вообще?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.08.2012, 16:48
Помогаю со студенческими работами здесь

Форматирование данных при выполнении запроса в Access
Подскажите пожалуйста, можно ли в Access при выполнении запроса форматировать данные (даты или вещественные числа) так, чтобы независимо от...

Ошибка изменения данных таблицы при выполнении запроса
Добрый день! У меня вопрос по изменении данных таблицы при выполнении запроса. Пример во вложении. Исходные данные следующие: 1....

Ошибка 404 при выполнении динамического запроса данных
Добрый день, коллеги! Возникла проблема с доступом пользователей к динамическому контенту посредством Ajax. Есть страница, на которой...

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

При выполнении запроса "Необработанное исключение типа SqlException" - "Invalid column name"
Сам запрос рабочий в SQL, проверял какие данные вводил, но не знаю в чем проблема. con.Open(); SqlDataAdapter...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru