Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Условия в запросе
Украинский 1С форум: всё про 1С 8.3, 1С 8.2, 1С 8.1, 1С 8.0, 1С 7.7 > Программисту > Программирование в 1С Предприятие 8.2 > Программирование обычных форм 1С 8.2 и не интерфейсной логики
Lefer
Доброго времени суток. Такой вот вопрос. Столкнулся с новым для себя, скорее с новым белым пятном в географии 1с механизма запросов. Есть справочник, который содержит в себе 10000 наименований и каждое из них делает 4 записи в регистр периодический независимый регистр сведений. Изначально был написан такой вот запрос:

    
Запрос          = Новый Запрос;
Запрос.Текст = "ВЫБРАТЬ
    |    ЦеныТоваровСрезПоследних.КатегорияЦены,
    |    ЦеныТоваровСрезПоследних.Цена,
    |    ЦеныТоваровСрезПоследних.Наценка
    |ИЗ
    |    РегистрСведений.ЦеныТоваров.СрезПоследних КАК ЦеныТоваровСрезПоследних
    |ГДЕ
    |    ЦеныТоваровСрезПоследних.Валюта           = &Валюта
    |    И ЦеныТоваровСрезПоследних.Товар          = &Товар
    |    И ЦеныТоваровСрезПоследних.КлассТовара = &КлассТовара
    |    И ЦеныТоваровСрезПоследних.КатегорияЦены <> &ЦенаПрих";
    Запрос.УстановитьПараметр("Валюта",ВалютаПрихода);
    Запрос.УстановитьПараметр("Товар",Ссылка);
    Запрос.УстановитьПараметр("КлассТовара",КлассТовара);
    Запрос.УстановитьПараметр("ЦенаПрих",Справочники.КатегорииЦен.ЦенаПриходная);


Данный запрос вызывался в процедуре "ПередОткрытие" формы элемента справочника и результатом его выполнения были выбранные категории цен, исключая приходную. В запросе не стоит условие "Дата" - в скрижалях от Радченко сказано, что если обращаемся к регистру, используя метод "СрезПоследних" то дата необязательна - 8 умная. В итоге такой запрос работал жутко медленно - открывался секунд через 15. Поставил все таки дату в условие - не помогло.

Написал вот такой запрос

        Запрос         = Новый Запрос;
    Запрос.Текст = "ВЫБРАТЬ
                   |    ЦеныТоваровСрезПоследних.КатегорияЦены,
                   |    ЦеныТоваровСрезПоследних.Цена,
                   |    ЦеныТоваровСрезПоследних.Наценка
                   |ИЗ
                   |    РегистрСведений.ЦеныТоваров.СрезПоследних(
                   |        &Дата,
                   |        Валюта          = &Валюта
                   |        И КатегорияЦены <> &Цена
                   |        И КлассТовара   = &КлассТовара
                   |        И Товар         = &Товар) КАК ЦеныТоваровСрезПоследних";
    Запрос.УстановитьПараметр("Валюта",ВалютаПрихода);
    Запрос.УстановитьПараметр("Товар",Ссылка);
    Запрос.УстановитьПараметр("КлассТовара",КлассТовара);
    Запрос.УстановитьПараметр("Цена",Справочники.КатегорииЦен.ЦенаПриходная);
    Запрос.УстановитьПараметр("Дата",ТекущаяДата());


Разница в том, что я не устанавливал условия на вкладке "Условия", а задал условия в параметрах виртуальной таблицы. Запрос отрабатывает моментально.
Такой вот механизм я подсмотрел в УПП в модуле справочника Номенклатура, когда они заполняют цены - "КоманднаяПанельЦеныПоставщикаПеречитатьТекущиеЦены(Кнопка)"... подскажите, пожалуйста, в чем разница между условиями и параметрами виртуальной таблицы???
Vofka
С параметрами виртуальной таблицы вы получаете только нужные записи.

С условиями вы получаете все записи, после чего они начинают фильтроваться по заданным условиями.
Lefer
Цитата(Vofka @ 15.12.10, 11:32) необходимо зарегистрироваться для просмотра ссылки
С параметрами виртуальной таблицы вы получаете только нужные записи.

С условиями вы получаете все записи, после чего они начинают фильтроваться по заданным условиями.


Получается, что устанавливая условия для виртуальной таблицы, мы таким образом заранее отсекаем ненужное и сокращаем объем выбираемых данных? То есть для работы с таблицей регистра в запросе условия ВЫБОРКИ данных устанавливать в параметрах виртуальной таблицы, а условия ОБРАБОТКИ в условиях?
Vofka
zetovich
1 вариант отберет с начало все, а потом наложит условие.
2 вариант отберет сразу по условию.
выводы делайте сами.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.