Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
1 / 1 / 0
Регистрация: 05.01.2010
Сообщений: 13

Ошибка подготовки параметризированного SQL запроса

08.01.2010, 14:51. Показов 2151. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Разрабатываю приложение в среде VS, язык С#, встраиваемая база данных Firebird Embedded.
При выполнении SQL запроса для добавления данных в таблицу БД появляется сообщение об ошибке:
«Ошибка подготовки SQL выражения.
Dynamic SQL Error
SQL error code = -104
Token unknown - line 2, column 124
@».

Прописываю следующий код:
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
OleDbDataAdapter da = new OleDbDataAdapter();
OleDbCommand cmd = new OleDbCommand();
da.InsertCommand = cmd;
da.InsertCommand.CommandType = CommandType.Text;
da.InsertCommand.Connection = myConnection;
 
//Добавляем 3 параметра к запросу
OleDbParameter contract_number = new OleDbParameter();
contract_number.ParameterName = "@CONTRACT_NUMBER";
contract_number.OleDbType = System.Data.OleDb.OleDbType.Integer;
contract_number.IsNullable = true;
contract_number.SourceColumn = "CONTRACT_NUMBER";
contract_number.Value = Contract_number;
da.InsertCommand.Parameters.Add(contract_number);
 
OleDbParameter client = new OleDbParameter();
client.ParameterName = "@CLIENTID";
client.OleDbType = System.Data.OleDb.OleDbType.Integer;
client.IsNullable = true;
client.SourceColumn = "CLIENTID";
client.Value = Clientid;
da.InsertCommand.Parameters.Add(client);
 
OleDbParameter samples_quantity = new OleDbParameter();
samples_quantity.ParameterName = "@SAMPLES_QUANTITY";
samples_quantity.OleDbType = System.Data.OleDb.OleDbType.Integer;
samples_quantity.IsNullable = true;
samples_quantity.SourceColumn = "SAMPLES_QUANTITY";
samples_quantity.Value = Samples_quantity;
da.InsertCommand.Parameters.Add(samples_quantity);
 
//1-й вариант SQL выражения выдает сообщение об ошибке 
 
da.InsertCommand.CommandText = "INSERT INTO \"CONTRACTLIST\" (\"CONTRACT_NUMBER\", \"CLIENTID\", \"SAMPLES_QUANTITY\") VALUES (@CONTRACT_NUMBER, @CLIENTID, @SAMPLES_QUANTITY)";
 
//2-й вариант SQL выражения выдает такое же сообщение об ошибке 
 
da.InsertCommand.CommandText = @"INSERT INTO ""CONTRACTS"" (""CONTRACT_NUMBER"", ""CLIENTID"", ""SAMPLES_QUANTITY"") VALUES (@CONTRACT_NUMBER, @CLIENTID, @SAMPLES_QUANTITY)";
 
da.InsertCommand.Connection.Open();
da.InsertCommand.Transaction = da.InsertCommand.Connection.BeginTransaction();
da.InsertCommand.ExecuteNonQuery(); //Здесь выдает сообщение!
da.InsertCommand.Transaction.Commit();
da.InsertCommand.Connection.Close();
Подскажите, пожалуйста, в чем может быть причина ошибки?
Спасибо всем ответившим.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.01.2010, 14:51
Ответы с готовыми решениями:

Ошибка в строке Sql запроса
str обычная строка такого типа "ddd" пытаюсь установить имя ячейки столбца Name значением из переменной str,но пишет ошибку ...

Ошибка SQL запроса к базе mdf с русскими символами
Здравствуйте, помогите пожалуйста, возникает ошибка при попытке SQL запроса к базе mdf(C#) с русскими символами, вот сам запрос: ...

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

1
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
09.01.2010, 12:40
Используйте вместо @CONTRACT_NUMBER - ? (тогда параметры в запрос нужно добавлять в порядке их появления в запросе).
Либо использовать :CONTRACT_NUMBER
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.01.2010, 12:40
Помогаю со студенческими работами здесь

SQL запросы, чем плоха конкатенация SQL запроса?
Опишу ситуацию, есть БД с несколькими таблицами, с которыми нужно совершать много разных операций при разных условиях. Операции...

Ошибка SQL запроса: SQL logic error or missing database
Здравствуйте, помогите решить проблему. Считываю бинарный файл и отправляю в БД(использую SQLite) с помощью массива. Отправляю массив в...

Ошибка SQL-запроса: You have an error in your SQL syntax near 'group(name_group,time)VALUES('123','00:00')'
Уже всю голову сломал, не могу понять в чем косяк? Текст ошибки:You have an error in your SQL syntax; check the manual that corresponds...

Ошибка SQL запроса , в базе работает, а через IBQuery в Delphi ошибка
В Combobox загружены имена организаций. Нужно выполнить запрос на вывод всех полей таблицы организаций при выборе имени в Combobox. При...

Ошибка SQL запроса #1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax t
Помогите пожалуйста! CREATE TABLE `tickets` ( `id` int(4) NOT NULL auto_increment, `user` int(11) NOT NULL default '0', ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru