8.х Остатки по дням.

Тема в разделе "Конфигурирование на платформе "1С:Предприятие 8"", создана пользователем Sorkin, 15 окт 2014.

  1. TopicStarter Overlay
    Sorkin
    Offline

    Sorkin Опытный в 1С

    Регистрация:
    30 май 2014
    Сообщения:
    106
    Симпатии:
    4
    Баллы:
    29
    Здравствуйте, подскажите.
    Делаю запрос.
    Код:
    ВЫБРАТЬ
        ХозрасчетныйОстаткиИОбороты.Счет,
        ХозрасчетныйОстаткиИОбороты.Субконто1,
        ХозрасчетныйОстаткиИОбороты.Субконто2,
        ХозрасчетныйОстаткиИОбороты.Организация,
        ХозрасчетныйОстаткиИОбороты.СуммаКонечныйОстатокКт КАК СуммаКонечныйОстатокКт,
        ХозрасчетныйОстаткиИОбороты.Период КАК Период
    ИЗ
        РегистрБухгалтерии.Хозрасчетный.ОстаткиИОбороты(&НачалоПериода, &КонецПериода, День, , Счет = &Счет, , Организация = &Организация) КАК ХозрасчетныйОстаткиИОбороты
    ГДЕ
        ХозрасчетныйОстаткиИОбороты.Субконто2 = &Субконто2
    
    УПОРЯДОЧИТЬ ПО
        ХозрасчетныйОстаткиИОбороты.Период
    ИТОГИ ПО
        Период ПЕРИОДАМИ(ДЕНЬ, , )
    но у меня остатки по дням не выходит, выводит только то когда был приход.
    А нужно на каждый день, где ошибка в запросе или что я не доделал?

    1231.jpg
  2. nomad_irk
    Online

    nomad_irk Гуру в 1С

    Регистрация:
    20 окт 2008
    Сообщения:
    9.843
    Симпатии:
    1.025
    Баллы:
    204
    Запрос написан верно и выдает верный результат.
    СКД умеет делать вывод так, как вам нужно.
  3. TopicStarter Overlay
    Sorkin
    Offline

    Sorkin Опытный в 1С

    Регистрация:
    30 май 2014
    Сообщения:
    106
    Симпатии:
    4
    Баллы:
    29
    сейчас попробую.
  4. Draco
    Offline

    Draco Модераторы Команда форума Модератор

    Регистрация:
    28 окт 2009
    Сообщения:
    13.722
    Симпатии:
    961
    Баллы:
    204
    Ну вы почитайте на формуах. Когда вы берете виртуальные таблицы - данные там будут только когда движения есть.
    Тут одним запросом не обойдешся.
    Уже даже сегодня писал. На форуме или в инете набериете. Остатки на каждый день СКД. и все поймете.
    если через СКД то там через два набора данных делается и свзяь их по параметру. Если через запросы то там через временные таблицы можно.
    Sorkin нравится это.
  5. TopicStarter Overlay
    Sorkin
    Offline

    Sorkin Опытный в 1С

    Регистрация:
    30 май 2014
    Сообщения:
    106
    Симпатии:
    4
    Баллы:
    29
    Код:
    ВЫБРАТЬ РАЗРЕШЕННЫЕ
        КалендарныеГрафики.ДатаГрафика
    ПОМЕСТИТЬ ВТ_Дни
    ИЗ
        РегистрСведений.КалендарныеГрафики КАК КалендарныеГрафики
    ГДЕ
        КалендарныеГрафики.ДатаГрафика МЕЖДУ &НачалоПериода И &КонецПериода
    ;
    
    ////////////////////////////////////////////////////////////////////////////////
    ВЫБРАТЬ РАЗРЕШЕННЫЕ
        ХозрасчетныйОстаткиИОбороты.Период КАК День,
        ХозрасчетныйОстаткиИОбороты.Субконто1 КАК Контрагент,
        ХозрасчетныйОстаткиИОбороты.Субконто2 КАК Договор,
        ХозрасчетныйОстаткиИОбороты.Счет,
        ХозрасчетныйОстаткиИОбороты.Организация,
        ХозрасчетныйОстаткиИОбороты.СуммаКонечныйОстатокКт КАК КонечныйОстатокКт
    ПОМЕСТИТЬ ВТ_Остатки
    ИЗ
        РегистрБухгалтерии.Хозрасчетный.ОстаткиИОбороты(&НачалоПериода, &КонецПериода, День, ДвиженияИГраницыПериода, Счет = &Счет, , Субконто2 = &Субконто2) КАК ХозрасчетныйОстаткиИОбороты
    ;
    
    ////////////////////////////////////////////////////////////////////////////////
    ВЫБРАТЬ РАЗРЕШЕННЫЕ
        ВТ_Дни.ДатаГрафика КАК ДатаГрафика,
        МАКСИМУМ(ВТ_Остатки.День) КАК ДатаОстатка
    ПОМЕСТИТЬ ВТ_ДатыОстатка
    ИЗ
        ВТ_Дни КАК ВТ_Дни
            ЛЕВОЕ СОЕДИНЕНИЕ ВТ_Остатки КАК ВТ_Остатки
            ПО ВТ_Дни.ДатаГрафика >= ВТ_Остатки.День
    
    СГРУППИРОВАТЬ ПО
        ВТ_Дни.ДатаГрафика
    ;
    
    ////////////////////////////////////////////////////////////////////////////////
    ВЫБРАТЬ
        ВТ_ДатыОстатка.ДатаГрафика КАК ДатаГрафика,
        ВТ_Остатки.Контрагент,
        ВТ_Остатки.Договор,
        ВТ_Остатки.Счет,
        ВТ_Остатки.Организация,
        ВТ_Остатки.КонечныйОстатокКт,
        ВЫБОР
            КОГДА ВТ_ДатыОстатка.ДатаГрафика = &КонецПериода
                ТОГДА ВТ_Остатки.КонечныйОстатокКт
            ИНАЧЕ 0
        КОНЕЦ КАК ОстатокИтоговый
    ИЗ
        ВТ_ДатыОстатка КАК ВТ_ДатыОстатка
            ВНУТРЕННЕЕ СОЕДИНЕНИЕ ВТ_Остатки КАК ВТ_Остатки
            ПО ВТ_ДатыОстатка.ДатаОстатка = ВТ_Остатки.День
    
    УПОРЯДОЧИТЬ ПО
        ДатаГрафика
    Вот так получилось без СКД.
    --- Объединение сообщений, 15 окт 2014 ---
    Спасибо, сделал.
    Последнее редактирование: 15 окт 2014