Сеня рядом и Белла пришел. Былое
UPSERT в БД Oracle (Python, SQLAlchemy)
Всем привет. Я дата-инженер и достаточно долгое время работал с БД PostgreSQL. Сменив работу я столкнулся с Oracle и его особенностями. Например, с отсутствием такой удобной конструкции при записи данных, как INSERT... ON CONFLICT DO UPDATE. Есть ее аналог, но чтобы понять объяснение из документации, нужно напрягать мозг. Напишу в том виде, в котором это было бы понятно мне, когда я впервые это увидел. Может, пригодится еще кому-то. Для записи я использую Python и SQLAlchemy, но программного кода здесь не будет, только SQL в нужном формате. Итак, вместо "INSERT … ON CONFLICT DO... "в Oracle используется MERGE...
Сравнение дат oracle
Сравнение дат в Oracle осуществляется с использованием различных операторов, функций и методов. Вот сравнительный анализ способов сравнения дат в Oracle, с примерами и пояснениями: 1. Операторы сравнения: = (равно), != (не равно), < (меньше), > (больше), <= (меньше или равно), >= (больше или равно): Эти операторы можно использовать напрямую для сравнения значений типа данных DATE, TIMESTAMP, TIMESTAMP WITH TIME ZONE, и TIMESTAMP WITH LOCAL TIME ZONE. Oracle сравнивает значения дат по их компонентам: год, месяц, день, час, минута, секунда. · SELECT * · FROM employees · WHERE hire_date = TO_DATE(’01-JAN-2000′,...