Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/18: Рейтинг темы: голосов - 18, средняя оценка - 4.72
0 / 0 / 0
Регистрация: 27.08.2022
Сообщений: 11

Запрос, который будет переводить сумму транзакций в usd с учетом того, что в таблице rates данные только за рабочие дни

27.08.2022, 10:18. Показов 4054. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте уважаемые форумчане!

Подскажите пожалуйста, как решить мне задачу. Каким образом можно добавить данные за выходные дни в rates? Как сделать что захватить день последнего рабочего дня перед выходными?

Есть две таблицы

Transactions с полями:
- Client_id,
- Report_date,
- Txn_amount

Rates с полями:
- Report_date,
- Ccy_code,
- CCy_rate.

Задача - написать запрос, который будет переводить сумму транзакций в usd (ccy_code = 840) с учетом того, что в таблице rates данные только за рабочие дни.
Транзакции, совершенные в выходные, пересчитываются по курсу последнего рабочего дня перед праздником/выходным.
Результат: Клиент, дата, сумма операций в usd.

Мое решение:
SQL
1
2
3
4
5
6
SELECT 
       client_id,
       transactions.report_date, 
       txn_amount / ccy_rate  AS txn_amount_usd
FROM transactions
FULL JOIN rates ON transactions.report_date = rates.report_date
Миниатюры
Запрос, который будет переводить сумму транзакций в usd с учетом того, что в таблице rates данные только за рабочие дни  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.08.2022, 10:18
Ответы с готовыми решениями:

Написать запрос, который будет переводить сумму транзакций в usd
Есть две таблицы Transactions с полями Client_id, Report_date, Txn_amount Rates с полями

SQL запрос, который будет возвращать первое несуществующее в таблице значение поля AI
CREATE TABLE IF NOT EXISTS `test` ( `num` int(11) NOT NULL, PRIMARY KEY (`num`) ); INSERT INTO `test` (`num`) VALUES...

Какова вероятность того, что пассажир,только что прибывший на вокзал, будет ждать электричку более 15 минут?
1)Электричка в нужном направлении уходит с вокзала каждые 30 минут.Какова вероятность того, что пассажир,только что прибывший на вокзал,...

10
Эксперт MS Access
 Аватар для Eugene-LS
12046 / 5828 / 1492
Регистрация: 05.10.2016
Сообщений: 16,406
27.08.2022, 10:47
Цитата Сообщение от beka_1 Посмотреть сообщение
Мое решение:
Вам нужно находить "ccy_rate" на дату "Report_date" или на дату последнего рабочего дня.
Опубликуйте БД - поковыряюсь ...
1
27.08.2022, 11:08
 Комментарий модератора 
beka_1,

Вам точно в раздел Access нужно?
Может, перенести тему в другой раздел?
0
598 / 404 / 51
Регистрация: 06.03.2022
Сообщений: 2,129
27.08.2022, 12:36
Отсюда не видно Вашу схему,но есть такой вариант:
Тбл.Операции\транзакции с полями(помимо других,нужных Вам)[дата] , [сумма] и [курс](куда автоматически подставить действующий курс из соответствующей таблицы).
Тбл.КурсыВалют с полями [курс],[датаС],[датаПО]-в операции подставлять курс(выбрать DLOOKUPом запись с пустым\действующий курс на дату оплаты\полем датаПО,которое заполнять при изменении курса и автоматически создавать новую запись с датойС=датаПО+1 и пустым,заполняемом руками,полем [курс]. Как-то так...а какой при этом будет день недели абсолютно фиолетово...
0
0 / 0 / 0
Регистрация: 27.08.2022
Сообщений: 11
27.08.2022, 14:28  [ТС]
Я это делаю в postgressql

Добавлено через 1 минуту
postgresql)
0
598 / 404 / 51
Регистрация: 06.03.2022
Сообщений: 2,129
27.08.2022, 14:38
Создайте запрос с вычисляемым полем с функцией Weekday и отберите по нему 1 or 7-это будут данные за суб. и вск.
0
Эксперт MS Access
 Аватар для Eugene-LS
12046 / 5828 / 1492
Регистрация: 05.10.2016
Сообщений: 16,406
27.08.2022, 14:49
Цитата Сообщение от beka_1 Посмотреть сообщение
Я это делаю в postgressql
И чё !? - Там экспорт данных забанили?
Раз уж запостили вопрос у нас: Есть шанс увидеть как на MS Access это можно сделать, а потом уже в свою эпостась переведёте ...
SQL - Он и в Африке ...

Добавлено через 7 минут
Цитата Сообщение от SDKU Посмотреть сообщение
и отберите по нему 1 or 7-это будут данные за суб. и вск.
+ Это должны быть данные да предыдущее "суб. и вск." относительно значения из "Report_date" ...
0
598 / 404 / 51
Регистрация: 06.03.2022
Сообщений: 2,129
27.08.2022, 14:55
Выполните просьбу
Цитата Сообщение от Eugene-LS Посмотреть сообщение
Опубликуйте БД - поковыряюсь ...
0
ᴁ ©
Эксперт MS Access
 Аватар для АЕ
4137 / 2431 / 503
Регистрация: 13.12.2016
Сообщений: 8,272
Записей в блоге: 5
27.08.2022, 15:05
beka_1, я не знаю как у вас в приложении, но в аксе я бы решал своей функцией и вот ее бы и воткнул в запрос.

Добавлено через 1 минуту
передавал бы в функцию 2 параметра - код валюты и дату, а она возвращала курс.
0
0 / 0 / 0
Регистрация: 27.08.2022
Сообщений: 11
27.08.2022, 18:40  [ТС]
Мне пока сложно справиться, я только учусь. Поэтому мои вопросы могут казаться глупыми, строго не судите)
0
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
27.08.2022, 19:24
SQL
1
2
3
4
SELECT t.*,t.Txn_amount*(SELECT last_value(r.CCy_rate) OVER(ORDER BY r.Report_date) 
                           FROM Rates r 
                           WHERE r.Ccy_code=840 AND r.Report_date<=t.Report_date)
  FROM Transactions t
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.08.2022, 19:24
Помогаю со студенческими работами здесь

Написать запрос, который будет выводить только имена состоящие из 4 букв
Имеем таблицу с именами и фамилиями. Есть пару строк, где имен не указано, только фамилии. Кто подскажет, какой оператор использовать для...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru