Реклама на этом месте
Форум 1С
Форум 1С
Программистам. Бухгалтерам. Администраторам. Пользователям
Задай вопрос - получи решение проблемы. Без троллинга и флуда.
11 Дек 2017, 20:26
МультиВход
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Не получили письмо с кодом активации?
 
collapse

Автор Тема: Ошибка SQL: Переполнение поля  (Прочитано 10164 раз)

0 Пользователей и 1 Гость просматривают эту тему.

Оффлайн malaxit

  • *
  • Сообщений: 6
  • РЕПУТАЦИЯ: 0
  • Регистрация: 2013-05-17
  • Сайт: 
Добрый день. Помогите пожалуйста устранить ошибку. В УПП редакция 1.3 (1.3.6.1)  при проведении "Отчет производства за смену" 1с выдаёт ошибку:
Ошибка при выполнении обработчика - 'ОбработкаПроведения'
по причине:
{ОбщийМодуль.УправлениеПроизводствомДвиженияПоРегистрам.Модуль(3672)}: Ошибка при вызове метода контекста (Выполнить)

по причине:
Ошибка выполнения запроса
по причине:
Ошибка при выполнении операции над данными:
Ошибка SQL: Переполнение поля
по причине:
Ошибка SQL: Переполнение поля

Предполагаю что ошибка возникает из за следующих строк запроса:
   Док.Количество *
  ТаблицаСтоимостиЗатратУУ.СтоимостьОстаток /
  ТаблицаСтоимостиЗатратУУ.КоличествоОстаток

Полный запрос имеет вид:
ВЫБРАТЬ
   ТаблицаАналитики.Подразделение,
   ТаблицаАналитики.ПодразделениеОрганизации,
   
   ТаблицаАналитики.Затрата,
   ТаблицаАналитики.ХарактеристикаЗатраты,
   ТаблицаАналитики.СерияЗатраты,
   ТаблицаАналитики.СтатьяЗатрат,
   
   ТаблицаАналитики.НоменклатурнаяГруппа,
   ТаблицаАналитики.Заказ КАК Заказ,

   ТаблицаАналитики.СчетУчета,

   //ДляРеглУчета СУММА(
   //ДляРеглУчета    ВЫБОР КОГДА ТаблицаАналитики.СчетУчетаНУ <> Неопределено ТОГДА
   //ДляРеглУчета       УчетЗатрат.СтоимостьНУОстаток
   //ДляРеглУчета    ИНАЧЕ
   //ДляРеглУчета       0
   //ДляРеглУчета    КОНЕЦ
   //ДляРеглУчета ) КАК СтоимостьНУОстаток,

   //ДляРеглУчета СУММА(
   //ДляРеглУчета    ВЫБОР КОГДА ТаблицаАналитики.СчетУчетаНУ <> Неопределено ТОГДА
   //ДляРеглУчета       УчетЗатрат.КоличествоНУОстаток
   //ДляРеглУчета    ИНАЧЕ
   //ДляРеглУчета       0
   //ДляРеглУчета    КОНЕЦ
   //ДляРеглУчета ) КАК КоличествоНУОстаток,

   СУММА(УчетЗатрат.СтоимостьОстаток) КАК СтоимостьОстаток,
   СУММА(УчетЗатрат.КоличествоОстаток) КАК КоличествоОстаток

ПОМЕСТИТЬ ТаблицаСтоимостиЗатрат
ИЗ
   РегистрНакопления.УчетЗатрат.Остатки(&КонДата,
      (
      АналитикаВидаУчета,
      АналитикаУчетаЗатрат,
      АналитикаРаспределенияЗатрат,
      АналитикаУчетаПартий
      ) В (
         ВЫБРАТЬ
             АналитикаВидаУчета,
            //ДляРеглУчета АналитикаВидаУчетаРегл,
            АналитикаУчетаЗатрат,
            АналитикаРаспределенияЗатрат,
            АналитикаУчетаПартий
         ИЗ
            ТаблицаАналитики
         )
   
   ) КАК УчетЗатрат
   
   ЛЕВОЕ СОЕДИНЕНИЕ
      ТаблицаАналитики КАК ТаблицаАналитики
   ПО
       УчетЗатрат.АналитикаВидаУчета = ТаблицаАналитики.АналитикаВидаУчета
      //ДляРеглУчета УчетЗатрат.АналитикаВидаУчета = ТаблицаАналитики.АналитикаВидаУчетаРегл
      И УчетЗатрат.АналитикаУчетаЗатрат = ТаблицаАналитики.АналитикаУчетаЗатрат
      И УчетЗатрат.АналитикаРаспределенияЗатрат = ТаблицаАналитики.АналитикаРаспределенияЗатрат
      И УчетЗатрат.АналитикаУчетаПартий = ТаблицаАналитики.АналитикаУчетаПартий

СГРУППИРОВАТЬ ПО
   ТаблицаАналитики.Подразделение,
   ТаблицаАналитики.ПодразделениеОрганизации,
   
   ТаблицаАналитики.Затрата,
   ТаблицаАналитики.ХарактеристикаЗатраты,
   ТаблицаАналитики.СерияЗатраты,
   ТаблицаАналитики.СтатьяЗатрат,
   
   ТаблицаАналитики.НоменклатурнаяГруппа,
   ТаблицаАналитики.Заказ,
   ТаблицаАналитики.СчетУчета
;
////////////////////////////////////////////////////////////////////////////


//ТекстТаблицаСтоимостиРегл

ВЫБРАТЬ
   Док.*,
   Док.СтатьяЗатрат.ВидЗатрат КАК ВидЗатрат,
   Док.СтатьяЗатрат.СтатусМатериальныхЗатрат КАК СтатусМатериальныхЗатрат,
   Неопределено КАК СпособРаспределенияЗатрат,
   Док.Номенклатура КАК Затрата,
   Док.ХарактеристикаНоменклатуры КАК ХарактеристикаЗатраты,
   Док.СерияНоменклатуры КАК СерияЗатраты,
   ВЫБОР КОГДА Док.КодОперации <> Неопределено ТОГДА
      Док.КодОперации
   ИНАЧЕ
      &ПрямыеЗатраты
   КОНЕЦ КАК КодОперации,

   ВЫБОР КОГДА Док.Заказ ССЫЛКА Документ.ЗаказПокупателя
      И Док.Заказ.ВидОперации = ЗНАЧЕНИЕ(Перечисление.ВидыОперацийЗаказПокупателя.Переработка)
   ТОГДА
      ЗНАЧЕНИЕ(Перечисление.ВариантыВыпускаПродукции.ПродукцияИзДавальческогоСырья)
   ИНАЧЕ
         Неопределено
   КОНЕЦ КАК ВариантВыпускаПродукции,

   &Ссылка КАК ДокументВыпуска,

      ВЫБОР КОГДА Док.ТипСтоимости = ЗНАЧЕНИЕ(Перечисление.ВидыНормативнойСтоимостиПроизводства.Фиксированная) ТОГДА
         Док.Сумма
       КОГДА ТаблицаСтоимостиЗатратУУ.КоличествоОстаток = 0
            ИЛИ ТаблицаСтоимостиЗатратУУ.КоличествоОстаток ЕСТЬ NULL ТОГДА
         0
      ИНАЧЕ
         Док.Количество *
         ТаблицаСтоимостиЗатратУУ.СтоимостьОстаток /
         ТаблицаСтоимостиЗатратУУ.КоличествоОстаток
      КОНЕЦ КАК СуммаУУ,

   //ПрямыеЗатратыБУ   ВЫБОР КОГДА Док.ТипСтоимости = ЗНАЧЕНИЕ(Перечисление.ВидыНормативнойСтоимостиПроизводства.Фиксированная) ТОГДА
   //ПрямыеЗатратыБУ      Док.СуммаРегл
   //ПрямыеЗатратыБУ    КОГДА ТаблицаСтоимостиЗатратРегл.КоличествоОстаток = 0
   //ПрямыеЗатратыБУ         ИЛИ ТаблицаСтоимостиЗатратРегл.КоличествоОстаток ЕСТЬ NULL ТОГДА
   //ПрямыеЗатратыБУ      0
   //ПрямыеЗатратыБУ   ИНАЧЕ
   //ПрямыеЗатратыБУ      Док.Количество *
   //ПрямыеЗатратыБУ      ТаблицаСтоимостиЗатратРегл.СтоимостьОстаток /
   //ПрямыеЗатратыБУ      ТаблицаСтоимостиЗатратРегл.КоличествоОстаток
   //ПрямыеЗатратыБУ   КОНЕЦ КАК СуммаБУ,

   //ПрямыеЗатратыБУ   ВЫБОР КОГДА Док.ТипСтоимости = ЗНАЧЕНИЕ(Перечисление.ВидыНормативнойСтоимостиПроизводства.Фиксированная) ТОГДА
   //ПрямыеЗатратыБУ      Док.СуммаНал
   //ПрямыеЗатратыБУ    КОГДА ТаблицаСтоимостиЗатратРегл.КоличествоНУОстаток = 0
   //ПрямыеЗатратыБУ         ИЛИ ТаблицаСтоимостиЗатратРегл.КоличествоНУОстаток ЕСТЬ NULL ТОГДА
   //ПрямыеЗатратыБУ      0
   //ПрямыеЗатратыБУ   ИНАЧЕ
   //ПрямыеЗатратыБУ      Док.Количество *
   //ПрямыеЗатратыБУ      ТаблицаСтоимостиЗатратРегл.СтоимостьНУОстаток /
   //ПрямыеЗатратыБУ      ТаблицаСтоимостиЗатратРегл.КоличествоНУОстаток
   //ПрямыеЗатратыБУ   КОНЕЦ КАК СуммаНУ,

   //ФиксСтоимость      Док.Сумма КАК СуммаУУ,
   //ФиксСтоимость      Док.СуммаРегл КАК СуммаБУ,
   //ФиксСтоимость      Док.СуммаНал КАК СуммаНУ,

   //ПоНулевойУУ       0 КАК СуммаУУ,
          0 КАК СуммаБУ,
          0 КАК СуммаНУ,

   Док.Количество

ИЗ
   ТаблицаДокумента КАК Док

      ЛЕВОЕ СОЕДИНЕНИЕ
         ТаблицаСтоимостиЗатрат КАК ТаблицаСтоимостиЗатратУУ
      ПО
         Док.Номенклатура = ТаблицаСтоимостиЗатратУУ.Затрата
         И Док.ХарактеристикаНоменклатуры = ТаблицаСтоимостиЗатратУУ.ХарактеристикаЗатраты
         И Док.СерияНоменклатуры = ТаблицаСтоимостиЗатратУУ.СерияЗатраты
         И Док.СтатьяЗатрат = ТаблицаСтоимостиЗатратУУ.СтатьяЗатрат
         И Док.НоменклатурнаяГруппаНЗП = ТаблицаСтоимостиЗатратУУ.НоменклатурнаяГруппа
         И Док.ЗаказНЗП = ТаблицаСтоимостиЗатратУУ.Заказ
         И Док.ПодразделениеНЗП = ТаблицаСтоимостиЗатратУУ.Подразделение

   //ПрямыеЗатратыБУ   ЛЕВОЕ СОЕДИНЕНИЕ
   //ПрямыеЗатратыБУ      ТаблицаСтоимостиЗатратРегл КАК ТаблицаСтоимостиЗатратРегл
   //ПрямыеЗатратыБУ   ПО
   //ПрямыеЗатратыБУ      Док.Номенклатура = ТаблицаСтоимостиЗатратРегл.Затрата
   //ПрямыеЗатратыБУ      И Док.ХарактеристикаНоменклатуры = ТаблицаСтоимостиЗатратРегл.ХарактеристикаЗатраты
   //ПрямыеЗатратыБУ      И Док.СерияНоменклатуры = ТаблицаСтоимостиЗатратРегл.СерияЗатраты
   //ПрямыеЗатратыБУ      И Док.СтатьяЗатрат = ТаблицаСтоимостиЗатратРегл.СтатьяЗатрат
   //ПрямыеЗатратыБУ      И Док.НоменклатурнаяГруппаНЗП = ТаблицаСтоимостиЗатратРегл.НоменклатурнаяГруппа
   //ПрямыеЗатратыБУ      И Док.ЗаказНЗПРегл = ТаблицаСтоимостиЗатратРегл.ЗаказРегл
   //ПрямыеЗатратыБУ      И (Док.СчетЗатрат = ТаблицаСтоимостиЗатратРегл.СчетУчета
   //ПрямыеЗатратыБУ         ИЛИ ТаблицаСтоимостиЗатратРегл.СчетУчета = Неопределено)
   //ПрямыеЗатратыБУ      И Док.ПодразделениеОрганизацииНЗП = ТаблицаСтоимостиЗатратРегл.ПодразделениеОрганизации

УПОРЯДОЧИТЬ ПО
   Док.НомерСтроки


Оффлайн Жукова

  • *
  • Сообщений: 3
  • РЕПУТАЦИЯ: 0
  • Регистрация: 2013-05-17
  • Сайт: 
  • Профессия: Программист 1С
Попробуйте применить ВЫРАЗИТЬ: ВЫРАЗИТЬ( Док.Количество *
  ТаблицаСтоимостиЗатратУУ.СтоимостьОстаток /
  ТаблицаСтоимостиЗатратУУ.КоличествоОстаток
КАК ЧИСЛО(15,2))...
Если не поможет (а скорее всего не поможет), я бы искала какое точно поле такую ошибку выдает. Например, закомментарить все выходные поля, кроме одного. А потом по одному убирать комментарий и смотреть, есть ли ошибка.
И да, лучше отчет сохранить как внешний, чтобы конфу каждый раз не обновлять.

Оффлайн malaxit

  • *
  • Сообщений: 6
  • РЕПУТАЦИЯ: 0
  • Регистрация: 2013-05-17
  • Сайт: 
Спасибо, не помогло. Интересно что ошибка проявляется не всегда, а только в том случае если в табличной части "Распределение материалов" в перечне материалов есть конкретная номенклатура, при её удалении документ можно провести.
Подскажите пожалуйста есть ли инструменты которые позволят локализовать эту ошибку.

Добавлено: 17 Май 2013, 14:19

Мои предположения подтвердились, закоментировав строки запроса:
Док.Количество *
  ТаблицаСтоимостиЗатратУУ.СтоимостьОстаток /
  ТаблицаСтоимостиЗатратУУ.КоличествоОстаток
Документ был проведён. Что делать дальше не могу понять ...


Последний раз редактировалось: malaxit; 17 Май 2013, 14:19. Причина: Объединение сообщений

Оффлайн Dethmontt

  • Денис
  • Модератор
  • *****
  • Сообщений: 2857
  • РЕПУТАЦИЯ: 546
  • КПД: 19%
  • Адын Эс
  • Регистрация: 2010-11-01
  • Сайт: 
  • Профессия: Программист 1С
Дело скорее всего не в запросе, а в одном из значений которые приходят сюда
 
"Док.Количество *"
  "ТаблицаСтоимостиЗатратУУ.СтоимостьОстаток /"
  "ТаблицаСтоимостиЗатратУУ.КоличествоОстаток"

Переполнение поля - это превышение размерности типа в SQL
Если долго всматриваться в учебник...то в голову может прийти мысль его открыть!

Оффлайн malaxit

  • *
  • Сообщений: 6
  • РЕПУТАЦИЯ: 0
  • Регистрация: 2013-05-17
  • Сайт: 
    Что такое переполнение - понятно. Но если в режиме предприятия данные можно было ввести, то получается что при выполнении в ходе манипуляций с ними произошло переполнение :-( может кто подскажет как действовать в такой ситуации, наверняка я не первый кто с этим столкнулся.

Оффлайн Dethmontt

  • Денис
  • Модератор
  • *****
  • Сообщений: 2857
  • РЕПУТАЦИЯ: 546
  • КПД: 19%
  • Адын Эс
  • Регистрация: 2010-11-01
  • Сайт: 
  • Профессия: Программист 1С
Сначала найди какой из полей переполняется.

Потом смотри как оно формируется. Если выбирается из базы то косяк в ДАННЫХ и нужно смотреть регистр!
Добавлено: 20 Май 2013, 11:24

Возможно значение переполнено уже в БАЗЕ и расчет тут не причом
Если долго всматриваться в учебник...то в голову может прийти мысль его открыть!


Теги:
 

При открытии обр-ки в "Предприятии" есть ошибка, а в "Отладке" нет

Автор proofetРаздел Конфигурирование, программирование в "1С - Предприятие 8"

Ответов: 2
Просмотров: 4522
Последний ответ 21 Сен 2011, 17:35
от proofet
ошибка "Невозможно обработать параметр "ПрофильПолномочийПользователя""

Автор lindeluРаздел Конфигурирование, программирование в "1С - Предприятие 8"

Ответов: 5
Просмотров: 6069
Последний ответ 06 Июн 2012, 09:15
от lindelu
Синтаксическая ошибка "В" Номенклатура.Ссылка = <<?>> В ИЕРАРХИИ(&Ссылка)

Автор maskitoРаздел Конфигурирование, программирование в "1С - Предприятие 8"

Ответов: 4
Просмотров: 4190
Последний ответ 28 Апр 2014, 15:53
от maskito
Ошибка при загрузке данных через (Обработка "Выгрузка и загрузка данных XML")

Автор Сергей_87Раздел Конфигурирование, программирование в "1С - Предприятие 8"

Ответов: 1
Просмотров: 8549
Последний ответ 26 Апр 2012, 23:08
от Dethmontt
Синтаксическая ошибка "ИЗ"

Автор kulkriseРаздел Конфигурирование, программирование в "1С - Предприятие 8"

Ответов: 4
Просмотров: 4564
Последний ответ 26 Янв 2014, 19:33
от kulkrise

* Живое общение

Не устроил ответ?

Зарегистрируйся и задай свой вопрос. Живое общение приносит результат намного быстрее.


Зарегистрироваться

* Реклама

Смотрите бесплатно более 300 видеоуроков по работе в 1С:Бухгалтерия 8 и 1C:ЗУП 8 ред. 3.0

СМОТРЕТЬ >>

* Поиск

* Последние задачи на разработку (фриланс)

* Реклама

* Последние вакансии

* Топ 10 авторов за месяц

Геннадий ОбьГЭС Геннадий ОбьГЭС
163 Сообщений
ilyay ilyay
75 Сообщений
oleg-x
56 Сообщений
alex0402
46 Сообщений
andron81_81
44 Сообщений
AIFrame
36 Сообщений
MuI_I_Ika MuI_I_Ika
33 Сообщений
BuhRust
28 Сообщений
Golickoff Golickoff
28 Сообщений
Dima Dddd Dima Dddd
26 Сообщений

* Кто онлайн

  • Точка Гостей: 340
  • Точка Скрытых: 0
  • Точка Пользователей: 2
  • Точка Сейчас на форуме:

* Облако тэгов

* Форум 1С с мобильного

* Инструменты

* Дополнительно

Поиск

 
SimplePortal 2.3.5 © 2008-2012, SimplePortal