Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/21: Рейтинг темы: голосов - 21, средняя оценка - 4.52
2 / 2 / 0
Регистрация: 04.06.2017
Сообщений: 35

Ошибка при выполнении запроса Trying to store a string of length 30 into field that can only contain 20

13.08.2018, 14:12. Показов 4262. Ответов 6

Студворк — интернет-сервис помощи студентам
Добрый день! Возникла проблема с IBQ...

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
with IBQSPRED do
  begin
    close;
    SQL.Clear;
    SQL.Add('select (case when npredu='''' then npred else npredu end) as npred from spred where kpred=:KodPred and kbank=:KodBank and nschet=:Nschet');
    ParamByName('KodPred').Value := IBQ_Zadan.FieldValues['kplat'];
    ParamByName('KodBank').Value := IBQ_Zadan.FieldValues['kmfo'];
    if trim(IBQ_Zadan.FieldValues['nschet']) = '0' then
      ParamByName('Nschet').Value := ''
    else
      ParamByName('Nschet').Value := IBQ_Zadan.FieldValues['nschet'];
      //ShowMessage(IBQ_Zadan.FieldValues['kplat']);
      //ShowMessage(IBQ_Zadan.FieldValues['kmfo']);
      //ShowMessage(IBQ_Zadan.FieldValues['nschet']);
    Open; //ERROR
    if IsEmpty then
      nplat := ''
    else
      nplat := trim(FieldByName('npred').AsString);
  end;
После "Open" вываливается ошибка: Trying to store a string of length 30 into field that can only contain 20.

Просмотрел записи в базе ни в одном поле размер не превышает 20 символов, выбранная запись по запросу - тоже. В чём может быть проблема? Помогите плиз!
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.08.2018, 14:12
Ответы с готовыми решениями:

БД interbase ошибка trying to store of length 41 into a field that can only contain 40
Решил свою программу переписать, все дополнительные значения перенести в базу данных До этого брал из txt таким образом ...

Ошибка при выполнении запроса
Ошибка : Warning: mysql_num_rows() expects parameter 1 to be resource, null given in Z:\home\localhost\www\prim\test\search.php on line 62...

Ошибка при выполнении запроса
Объясните, пжлст, ошибку при выполнении запроса и возможные пути исправления: ...

6
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
13.08.2018, 14:50
какой тип у nplat?
0
2 / 2 / 0
Регистрация: 04.06.2017
Сообщений: 35
13.08.2018, 15:09  [ТС]
Алекcей, String
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
13.08.2018, 15:19
может быть дело в
Delphi
1
ParamByName('Nschet').Value := IBQ_Zadan.FieldValues['nschet'];
т.е. длина поля Nschet в IBQSPRED = 20, а в IBQ_Zadan 30?
1
2 / 2 / 0
Регистрация: 04.06.2017
Сообщений: 35
13.08.2018, 15:35  [ТС]
Алекcей, Хм, да действительно в Zadan это поле действительно 30... Но как это может быть связано с записями? Ведь выбранная по запросу запись не превышает 20-ти знаков. И самое главное как исправить?

Добавлено через 6 минут
Алекcей, Всё в ZADAN изменил размер на 20 и отчёт выдался успешно) Спасибо Вам огромное!
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
13.08.2018, 15:39
Лучший ответ Сообщение было отмечено SaneK_UA как решение

Решение

попробуйте так:
Delphi
1
      ParamByName('Nschet').Value := Copy(Trim(IBQ_Zadan.FieldByName('nschet').asString),1,20);
Добавлено через 2 минуты
и еще мне не нравится
Delphi
1
2
if trim(IBQ_Zadan.FieldValues['nschet']) = '0' then
      ParamByName('Nschet').Value := ''
точно "пустое значение" поля Nschet в IBQSPRED хранится в виде '', а не null?
1
2 / 2 / 0
Регистрация: 04.06.2017
Сообщений: 35
14.08.2018, 15:21  [ТС]
Алекcей, Попробовал этим способом:
Delphi
1
 ParamByName('Nschet').Value := Copy(Trim(IBQ_Zadan.FieldByName('nschet').asString),1,20);
Всё работает) Вернул в базе значение 30 т.к та ошибка вылазила в другом месте)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.08.2018, 15:21
Помогаю со студенческими работами здесь

Ошибка при выполнении запроса
Пытаюсь выполнить запрос вот такого вида UPDATE table_name SET interval='60' WHERE user_id=221; и в ответ получаю ошибку #1064 - You...

Ошибка при выполнении запроса к БД
Всем привет! Учу PHP по учебнику "Изучаем PHP и MySQL" Л.Бейли. Дошел до момента соединения с MySQL посредствам PHP. Перепробовал массу...

Ошибка при выполнении запроса
Добрый вечер! (под вечер голова уже перестала работать) Есть простенькая БД, в ней одна таблица главная, две подчиненные. Необходимо...

Ошибка при выполнении запроса
Вот код запроса на выборку из таблици. public ResultSet GetDataSet() { // метод поверне об’єкт НАБІР ЗАПИСІВ // який...

Ошибка при выполнении запроса
Здравствуйте,помогите пожалуйста! Запускаю программу мне выдает такие ошибки. Помогите мне ее открыть или что-то не правильно сделано


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[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
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru