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

Аргументы имеют неверный тип, выходят за пределы

01.11.2013, 10:32. Показов 2508. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго времени суток. Недавно перешел на C++ Builder XE4 и возникла проблема с тем кодом который отлично работал в 10-ом билдере.
Проблемный код. Вылет на выделенной строке, при построчном выполнении.
C++
1
2
3
4
5
6
7
8
9
10
11
TADOQuery *query = new TADOQuery(DataMod);
            query->Connection = DataMod->Connection;
            query->SQL->Clear();
            // Ошибка в этой строке            
            query->SQL->Add("SELECT EXISTS (SELECT pInvoiceNumber FROM tInvoice WHERE pInvoiceNumber = :invoiceNumber) as pExists"); 
            ConfigureParam(query->Parameters->ParamByName("invoiceNumber"), ftString, "123456", 255, 0);
            query->Open();
            for(int i = 0; i < query->RecordCount; i++){
                ShowMessage(query->FieldByName("pExists")->AsInteger);
                query->RecNo++;
            }
C++
1
2
3
4
5
6
7
 Функция ConfigureParam
void    __fastcall ConfigureParam(TParameter *param, TFieldType dataType, Variant value, int size, int precision){
    param->DataType = dataType;
    param->Size = size;
    param->Value = value;
    param->Precision = precision;
}
В БД поле pInvoiceNumber типа VARCHAR. Такая же проблема и при работе с полем AUTO_INCREMENT:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
try{
        TADOQuery *query = new TADOQuery(DataMod);
        try {
            query->Connection = DataMod->Connection;
            query->Connection->BeginTrans();
             // Удаление из содержимого накладной
            query->SQL->Clear();
            query->SQL->Text = "DELETE FROM tInvoiceContent "
                                "WHERE pInventoryNumber=:inventoryNumber "
                                "AND pInvoiceNumber=:invoiceNumber "
                                "AND pID=:idParam ";
            ConfigureParam(query->Parameters->ParamByName("inventoryNumber"), ftString, inventoryNumber);
            ConfigureParam(query->Parameters->ParamByName("invoiceNumber"), ftString, invoiceNumber);
            ConfigureParam(query->Parameters->ParamByName("idParam"), ftLargeint, id);
            query->ExecSQL();
            // Отнимаем со склада к-во удаляемого товара
            OperationWithStorageCount(inventoryNumber, depotName, count, true);
            DataMod->Connection->CommitTrans();
        } __finally {
            delete query;
        }
    }
Тут проблема проявляется только если есть параметр idParam. Если его убрать ошибка пропадает. Уже 3-ий день меняю типы данных и размеры полей но пока безрезультатно.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.11.2013, 10:32
Ответы с готовыми решениями:

Параметры SQL (:Par) ошибка EOleException with message 'Аргументы имеют неверный тип, выходят за пределы'
У меня ХЕ4. работаю с mysql Изначально ошибка возникла когда я взял примеры кода отсюда, с insert поле blob через параметр ...

Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или вступают в конфликт друг с другом
Доброго времени суток! Пытаюсь установить на таблицу (ADOTable) фильтр DM-&gt;tMain-&gt;Filter=&quot;Year_ind =...

Ошибка: "Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или вступают в конфликт"
Мне нужно отсортировать несколько столбцов по клику на заголовке столбца в dbgrid, есть столбцы с числовыми значениями, есть с текстовыми....

1
0 / 0 / 0
Регистрация: 20.04.2013
Сообщений: 3
03.11.2013, 13:30  [ТС]
Вопрос снят. Просто сделал ребилд проекта, он все собрал по новой и проблема ушла, при периодических ее появлениях новый ребилд спасает ситуацию.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.11.2013, 13:30
Помогаю со студенческими работами здесь

"Аргументы имеют неверный тип" при фильтрации
ADOTablePatient-&gt;Filtered=false; ADOTablePatient-&gt;Filter=&quot; LIKE '%&quot;+EditSearch-&gt;Text+&quot;%'&quot;; ADOTablePatient-&gt;Filtered=true; if...

TADOQuery "Аргументы имеют неверный тип" Ошибка
ошибка вываливается в момент добавления нового запроса: db_query-&gt;SQL-&gt;Clear(); db_query-&gt;SQL-&gt;Add(&quot;SELECT COUNT(`id`) as...

Аргументы имеют неверный тип, выходят за пределы допустимого диапазона
Имеется база данных Access. Есть две таблицы: &quot;Порты&quot; и &quot;Устройства&quot;. В таблице &quot;Порты&quot; есть поля &quot;Код устройства&quot; и...

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

Тип ошибки: ADODB.Recordset (0x800A0BB9) Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или ...
Народ здравствуй! Проблема не могу добавить запись в базу! Открываю соединение Set Cnxn2 =...


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

Или воспользуйтесь поиском по форуму:
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