Форум программистов, компьютерный форум, киберфорум
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. Показов 4955. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru