Получить курс валюты на каждый день

20.03.15

Разработка - Запросы

Иногда при разработке отчетов, обработок необходимо получить курс валюты на каждый день.
Это особенно актуально, если курс вносится не ежедневно

В ходе разработки хитрого отчета потребовалось получить курсы валют на каждый день произвольного периода. 

Первый совет мне дали такой - использовать цикл.

Я посчитал, что это не кошерно (как говорят еврейские программеры), и к тому же я использовал СКД для построения отчета.

В итоге удалось получить курсы валюты за период следующим запросом:

 

ВЫБРАТЬ
	РегламентированныйПроизводственныйКалендарь.ДатаКалендаря КАК ДатаМесяц
ПОМЕСТИТЬ ДатаМесяцВТ
ИЗ
	РегистрСведений.РегламентированныйПроизводственныйКалендарь КАК РегламентированныйПроизводственныйКалендарь
ГДЕ
	РегламентированныйПроизводственныйКалендарь.ДатаКалендаря МЕЖДУ &ДатаНач И &ДатаКон
;

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

СГРУППИРОВАТЬ ПО
	КурсыВалют.Валюта,
	ДатаМесяцВТ.ДатаМесяц
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	МаксДатаКурсВТ.Период,
	МаксДатаКурсВТ.ДатаМесяц,
	МаксДатаКурсВТ.Валюта,
	КурсыВалют.Курс,
	КурсыВалют.Кратность
ИЗ
	МаксДатаКурсВТ КАК МаксДатаКурсВТ
		ВНУТРЕННЕЕ СОЕДИНЕНИЕ РегистрСведений.КурсыВалют КАК КурсыВалют
		ПО МаксДатаКурсВТ.Валюта = КурсыВалют.Валюта
			И МаксДатаКурсВТ.Период = КурсыВалют.Период

УПОРЯДОЧИТЬ ПО
	ДатаМесяц


курс валюта

См. также

SALE! 20%

Infostart Toolkit: Инструменты разработчика 1С 8.3 на управляемых формах

Инструментарий разработчика Роли и права Запросы СКД Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Конфигурации 1cv8 Платные (руб)

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

13000 10400 руб.

02.09.2020    122142    670    389    

714

Для чего используют конструкцию запроса "ГДЕ ЛОЖЬ" в СКД на примере конфигурации 1С:ERP

Запросы СКД Платформа 1С v8.3 Запросы Система компоновки данных 1С:ERP Управление предприятием 2 Бесплатно (free)

В типовых конфигурациях разработчики компании 1С иногда используют в отчетах, построенных на СКД, такую конструкцию, как "ГДЕ ЛОЖЬ". Такая конструкция говорит о том, что данные в запросе не будут получены совсем. Для чего же нужен тогда запрос?

13.02.2024    5746    KawaNoNeko    23    

23

Набор-объект для СКД по тексту или запросу

Запросы СКД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

Есть список полей в виде текста, или запрос - закидываем в набор СКД.

1 стартмани

31.01.2024    2000    2    Yashazz    0    

29

Запрос 1С copilot

Инструментарий разработчика Запросы Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

Пишем на человеческом языке, что нам надо, и получаем текст запроса на языке 1С. Используются большие языковые модели (LLM GPT) от OpenAI или Яндекс на выбор.

5 стартмани

15.01.2024    6284    31    mkalimulin    25    

50

PrintWizard: поддержка представлений ЗУП в конструкторе

Инструментарий разработчика Запросы Платформа 1С v8.3 Бесплатно (free)

Одной из интересных задач, стоящих в процессе разработки, была поддержка механизма представлений в ЗУП. Но не просто возможность исполнения запросов с ними. Основная проблема была в том, чтобы с ними было удобно работать, а именно: создавать, модифицировать и отлаживать. Кратко о том, что в итоге получилось...

14.12.2023    1742    vandalsvq    7    

29

Объектная модель запроса "Схема запроса" 2

Запросы Платформа 1С v8.3 Запросы Конфигурации 1cv8 Бесплатно (free)

Далеко уже не новый тип данных "Схема запроса". Статья о том, как использовать его "попроще". Примеры создания текста запроса с нуля и изменение имеющегося запроса.

06.12.2023    5388    user1923546    26    

43

Начните уже использовать хранилище запросов

HighLoad оптимизация Запросы

Очень немногие из тех, кто занимается поддержкой MS SQL, работают с хранилищем запросов. А ведь хранилище запросов – это очень удобный, мощный и, главное, бесплатный инструмент, позволяющий быстро найти и локализовать проблему производительности и потребления ресурсов запросами. В статье расскажем о том, как использовать хранилище запросов в MS SQL и какие плюсы и минусы у него есть.

11.10.2023    16184    skovpin_sa    14    

98
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. vano-ekt 123 20.03.15 12:22 Сейчас в теме
миллионы веток на тему среза последних на каждый день
народ даже сравнивает подходы в некоторых
http://www.forum.mista.ru/topic.php?id=529513

к чему это здесь?
Silenser; Dach; +2 Ответить
4. akey 5 20.03.15 23:45 Сейчас в теме
(1) vano-ekt,

Ответ на коммент от vano-ekt:

в приведенной Вами ссылке - возможно пример на дату заказа, но в моем
посте - курс валюты на каждый день периода, что есть 2 большие разницы

И мне кажется пост будет кому-то полезен

master555; RibD; user753110; +3 Ответить
12. user753110 08.05.18 05:51 Сейчас в теме
(4)
- курс валюты на каждый день периода, что есть 2


вот мне он был очень полезным)).
2. vano-ekt 123 20.03.15 12:25 Сейчас в теме
надо Knowledge Book на ИСе завести для подобных публикаций и туда либо постить, либо посылать
user753110; theshadowco; +2 Ответить
3. webester 26 20.03.15 14:20 Сейчас в теме
Попытался развернуть максимально подробно тему среза последних на каждый день http://developer1c.ru/posts/009_SliceLast/ расскажите, получилось?
5. akey 5 20.03.15 23:56 Сейчас в теме
(3) webester,

Здравствуйте, webester

Если вопрос ко мне, мое мнение - мне кажется все смешано в посте.
Думаю стоит разделить посты по функциональному назначению.
И описание запроса - считаю лучше короткие емкие комментарии.
И обратите внимание, проверьте результат запроса с получением МАКСИМУМ(Даты)

С уважением, Игорь
6. jobkostya1c_ERP 100 21.03.15 09:19 Сейчас в теме
Вот, маленькое и дельное решение. Не раз было нужно. Стоит запомнить.
7. vano-ekt 123 21.03.15 09:20 Сейчас в теме
и еще. во многих конфигурациях нет регистра сведений "РегламентированныйПроизводственныйКалендарь", а в половине тех, где есть - он не заполнен.
есть куча веток, например, про расчет цен на каждый день (манагеры у нас любят формировать остатки в (!) продажных ценах, зачем - это отдельный вопрос)
и в таких темах как правило есть решение.
На ИСе интересная публикация тут - http://infostart.ru/public/77568/
8. akey 5 21.03.15 13:34 Сейчас в теме
(7) vano-ekt,

Добрый день

Про регистр сведений Вы правы.
Но я повторюсь, - просто потому, что может кому-нибудь пригодится.
Тем более человек в комментах уже отписал, что воспользуется

С уважением, Игорь


9. akey 5 21.03.15 13:52 Сейчас в теме
(7) vano-ekt,

PS Спасибо за ссылку, иногда применяю различные наборы в СКД

С уважением, Игорь
10. vde69 925 25.03.15 10:20 Сейчас в теме
ВЫБРАТЬ
	ВложенныйЗапрос.ДатаКалендаря КАК ДатаКалендаря,
	ВложенныйЗапрос.Валюта КАК Валюта,
	КурсыВалют.Курс
ПОМЕСТИТЬ КурсыВалют
ИЗ
	(ВЫБРАТЬ РАЗЛИЧНЫЕ
		РегламентированныйПроизводственныйКалендарь.ДатаКалендаря КАК ДатаКалендаря,
		МАКСИМУМ(КурсыВалют.Период) КАК ДатаКурса,
		КурсыВалют.Валюта КАК Валюта
	ИЗ
		РегистрСведений.РегламентированныйПроизводственныйКалендарь КАК РегламентированныйПроизводственныйКалендарь
			ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.КурсыВалют КАК КурсыВалют
			ПО РегламентированныйПроизводственныйКалендарь.ДатаКалендаря >= КурсыВалют.Период
	
	СГРУППИРОВАТЬ ПО
		РегламентированныйПроизводственныйКалендарь.ДатаКалендаря,
		КурсыВалют.Валюта) КАК ВложенныйЗапрос
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.КурсыВалют КАК КурсыВалют
		ПО ВложенныйЗапрос.ДатаКурса = КурсыВалют.Период
			И ВложенныйЗапрос.Валюта = КурсыВалют.Валюта

ИНДЕКСИРОВАТЬ ПО
	Валюта,
	ДатаКалендаря
;
Показать
11. akey 5 01.04.15 08:57 Сейчас в теме
(10) vde69,
Привет

Неплохо.

Тогда напиши одним запросом:

Определить наиболее позднюю цену товара по дате в каждом месяце и пересчет
в рубли по курсу на дату цены.
(Цена из регистра сведений "Цены номенклатуры")

если цена не была задана в текущем месяце, тогда
определяется цена предыдущего месяца и пересчитывается
по курсу на 1 число текущего месяца.

Задача мной решена, но интересно увидеть в одном запросе

С уважением, Игорь
Оставьте свое сообщение