Oracle Developer👨🏻‍💻
3.22K subscribers
610 photos
68 videos
2 files
488 links
🔝 канал о разработке в СУБД Oracle:
SQL, PL/SQL, оптимизация, архитектура и многое другое...

Backend-pro.ru - обучение по различным программам, связанных с backend-разработкой для ФЛ и ЮЛ.

Отец-основатель: @denis_dbd Кивилёв Денис
Download Telegram
Всем привет!

Вполне вероятно, что, проходя собеседование на DBD или Backend-разработчика вы можете столкнуться с таким вопросом:
“Какая разница между UNION и UNION ALL с точки зрения оптимизации?”

Что ответите?

Разбор задачи с планами запросов, как обычно, в четверг 🎓
Не переключайтесь 😉


Интересно вам уже задавали на собесе этот вопрос? Голосовалка под постом 📊

#задача
Разница между UNION и UNION ALL с точки зрения оптимизации

Постановка задачи в посте вторника.

Начнем с простого. Что это за операции?
▫️UNION - объединяет два множества, оставляет только уникальные значения.
▫️UNION ALL - объединяет два множества, значения не уникальны, т.е. могут быть повторы.
Пока разница очевидна.

Пример:
select some_col1 from tab1
union
select some_col1 from tab2;

Давайте подумаем, а в чем различие операций на уровне выполнения. За счет чего достигается уникальность отдаваемых значений в UNION?

За счет дополнительного шага сортировки. И это прекрасно видно в плане запроса. После шага UNION-ALL выполняется SORT.
Я всегда говорю, если вам сортировка не требуется, то не надо её делать. Избавляемся от лишних сортировок.

⚠️ Возьмите за правило, использовать по умолчанию операцию UNION ALL, которая не выполняет сортировку. Только, если по бизнес-процессу требуется уникальность значений используйте UNION. Помогите СУБД избавиться от лишней работы 😉

#оптимизация #union #unionall
Друзья, всем привет!
Сегодняшний пост про внутреннюю жизнь канала.

1️⃣ Нативная реклама от Telegram
Телеграм стал монетизировать свою аудиторию. Начали размещать объявления в каналах. Когда вы видите рекламный пост с пометкой sponsored (как на скрине выше), это вот оно. Я не могу повлиять на ее отображение. Прошу отнестись к этому с пониманием.

Я иногда, размещаю рекламные посты с тегом #реклама. Деньги идут на продвижение канала, ибо для меня это не бесплатно. И да, расходы больше чем доходы.

2️⃣ Комментарии к постам
К сожалению, не ко всем постам добавляются нативные комментарии. Если пост с голосованием или ссылками в виде кнопки, то плашка с комментами не отображается.

Но! есть выход. Вы можете вступить в чат канала. И тогда у вас появится возможность комментировать любой пост в канале. Некоторое количество подписчиков уже там.
Нужно жямкнуть свойства канала -> View discussion -> Join group
Велком!

Кстати, в понедельник, будет кое-что интересное 😉

Всем хороших выходных! 👯‍♀️
Друзья, всем привет!

Я уже давно “закидывал удочку” на тему авторских постов в канале. Давайте еще раз озвучу мысль 💡

У нас тут абсолютно разные люди - по специализациям, по уровню знаний, по уникальному опыту. Этим можно было поделиться с другими коллегами.
Я даю возможность любому желающему опубликовать свой пост, задачу\решение, вопрос с собеседования или что-то другое интересное для аудитории канала. Естественно, с указанием автора.

Это отличная возможность, поделиться вашими знаниями, получить обратную связь, пообщаться с коллегами 💬

Конечно, есть определенные правила, налагаемые в основном, форматом Telegram. Посты должны быть краткими, отформатированными, отражающими суть. Как форматировать посты можно посмотреть на примере моих. Все это обсуждается в личке.

В эту среду, я опубликую пост от нашего подписчика. Это будет первый пост подобного рода 👍

Хочу напомнить, что в этом канале нет места негативу, наоборот, приветствуется поддержка и конструктивные замечания.

Всем хорошей недели!
Друзья, всем привет!
Как и обещал, ниже пост нашего подписчика ⬇️😉
Функции SQL vs Функции PL/SQL

Всем привет!
Вы уже задумывались о различиях между стандартными SQL и PL/SQL функциями? «А разве, между ними существуют различия?» - спросит новичок.
⚠️ Да, это разные функции и иногда они ведут себя по-разному.

В Oracle Database, как известно, есть два разных движка: для выполнения SQL-запросов и для PL/SQL-кода. Как все знают, следует избегать лишних переключения между этими движками. Чтобы таких переключений происходило как можно меньше, для SQL и PLSQL имеются свои реализации стандартных функций, описанных в документации. Они работают почти всегда одинаково и в обычной практике мы их не различаем, Например:
declare
my_var integer;
begin
select nvl(c.a, c.b) into my_var from my_table c; -- Вызов SQL-функции
my_var := nvl(my_var, 0); -- Вызов PL/SQL-функции
end;
/
Зачем нам нужно помнить о разных функциях? Причин несколько:
1️⃣ В PL/SQL может не оказаться соответствующей функции из SQL. Например, вы не сможете в PL/SQL-коде напрямую вызвать SQL-функции NVL2 и DECODE. Видимо, разработчики не стали включать в состав языка эти функции посчитав достаточно универсальной конструкцию CASE. Наличие интересующей функции можно проверить в пакете SYS.STANDARD. Также можно обратиться к документации на язык PL/SQL и проверить вызов на практике в обычном анонимном PL/SQL-блоке.

2️⃣ В SQL может не оказаться "своей" вызываемой функции. В таком случае можно попробовать обратиться к PL/SQL-функции напрямую через пакет SYS.STANDARD. Например:
select sys.standard.sqlcode from dual
В таком случае произойдёт то самое переключение контекста. Но не всякая PL/SQL-функция доступна в SQL из-за различий в поддерживаемых типах данных (Движок SQL ничего не знает о типе BOOLEAN).

3️⃣ Одноимённые реализации функции в SQL и PL/SQL-движках могут выдавать разные результаты. К сожалению, такое иногда встречается, поскольку каждую из реализаций внутри Oracle Database писали и поддерживали разные люди. Я натыкался на различия в результатах для функции TO_CHAR(left number, format varchar2, parms varchar2). Функции применяли разное выравнивание пробелами и приходилось прилагать дополнительные усилия, чтобы преобразование везде работало одинаково.

Пожалуйста, напишите в комментариях, встречалось ли вам что-то подобное.

Автор: @alexeionin

#функции
Друзья, всем привет!

А у нас сегодня вакансия с релокейтом в Гданьск (Польша). Вдруг кто-то хочет поменять локацию? Ну, вдруг 😉

Кратко, чем необходимо заниматься: миграция с разных СУБД в облако от Амазона.
Причем судя по описанию, ребята готовы обучать: No previous cloud experience is required for this job

В общем, если интересно, пишите @Distorge

https://jobs-us-east.amazon.com/es/jobs/1676280/database-engineer-aws-database-migration-accelerator

#вакансия
Подсветка интерфейса в зависимости от БД

Всем привет!
Пост будет полезен тем, кто использует IDE PL/SQL Developer.

100% вы встречались с ситуацией, когда выполняли скрипт не на той БД, не в той среде и т.п. Для предупреждения таких фейлов, многие IDE позволяют раскрашивать интерфейс в зависимости от коннекта к той или иной БД.
Не исключение мой любимый инструмент - PL/SQL Developer. Но не многие DBD/DBA знают про эту возможность.

Если зайти в меню Preferences -> Appearance, то в разделе “Connection Indicators” можно задать правила для подкрашивания интерфейса.

Шаблоны могут быть такими:
▫️ *@*dev
▫️ myuser@*
▫️ myser@some_proddb и т.д.

Для каждого шаблона задается цвет. Обычно делают: красный для Prod-сред, желтый для тестовых, зеленый для dev.

На скрине я подключен к БД содержащей в строке подключения слово dev. Соответственно, индикаторы подсвечены зеленым.

В PL/SQL Developer’e очень много разных фишек. Могу поделиться, если интересно 😉

Всем хорошей рабочей недели 👍

#ide
Recall Statement - Перевызов запроса

Всем привет!
Еще один пост для тех кто использует IDE PL/SQL Developer.

Есть возможность открыть список выполнявшихся команд в IDE. Экономит время и нервы. Нет необходимости писать запрос заново, можно взять уже когда-то написанный. Я достаточно часто использую. Как это выглядит см скрин ⬆️

Открыть можно через комбинацию - CNTRL+E или меню Edit -> Recall Statement.
Появится окно с выполненными запросами. Можно сортировать по дате, по тексту, по коннекту. Если не ошибаюсь, в 14й версии PL/SQL Developer добавили возможность фильтрации, раньше этого очень не хватало.

Количество сохраняемых запросов можно установить в настройках: Configure -> Preferences -> Tools -> Recall Statement.

По-моему, в dbForge и в TOAD тоже есть такие возможности.
DataGrip? SQL Developer? DBeaver?
Можете написать в комментах про свою любимую IDE.

Удобный настроенный инструмент облегчает и ускоряет любую работу 😉

#ide
Как готовят Oracle в Спортмастере

Друзья, всем привет!

В рабочих чатиках уже давно мелькало это интервью. Вполне вероятно, что вы его уже видели, но у меня все как-то не доходили руки. Наконец-то, на этих выходных удалось урвать почти час свободного времени (на скорости x1.25) на просмотр.
Было интересно послушать, чем живет разработка в “Спортмастере”.
Моё мнение, вполне себе приятное интересное интервью.

Коллеги используют (тезисно):
▫️GitLab для поставки инкремента;
▫️EBR для наката программных объектов без остановки;
▫️Crucible для code-review;
▫️SonarQube для автоматической проверки кода;
▫️Pluggable Database для создания окружения;
▫️Unit-тестирование (utPL/SQL) и др.

Отличный джентльменский набор. Такое не в каждой компании увидишь. К слову сказать, в Qiwi, где я сейчас имею счастье работать, большая часть из этого также используется. Привет коллегам 😉

Я впервые публикую видео не со своего канала. Возможно, стоит это делать чаще, с интересными материалами.
Приятного просмотра!

Как готовят Oracle в Спортмастере / Максим Пермяков

#видео
1👍1
Задача
Дана функция - sleep. Просто засыпание на N секунд с возможностью использования как функции в SQL и PL/SQL. Всегда возвращается “1”.

create or replace function sleep(p_sec number) return number
is
begin
dbms_session.sleep(p_sec); -- 18+
-- dbms_lock.sleep(p_sec); -- до 18
return 1;
end;
/

Выполняется такой запрос:
select nvl(sleep(5), sleep(10)) from dual;

За сколько секунд он выполнится?

Рекомендую не повторять этот код, а подумать и выбрать ответ. И только после этого, повторить в СУБД и проверить себя.

#задача
Задача: постановка в посте вторника.

Решение:
Вспомним для чего нужна функция NVL. Если первый аргумент null, то возвращается второй аргумент.
На примере: nvl(null, 2), результатом будет “2”.

Тогда какой правильный ответ в задаче?
Первый аргумент возвращает “1” - не null. Значит запрос выполнится за 5 секунд?

К сожалению, нет. Не важно какое значение в первом аргументе (null, не null), второй аргумент будет вычисляться всегда. Это допустимо, когда это просто литерал (как в примере выше). Но если это что-то вычисляемое или получение значение из сиквенса, то мы столкнемся с сайд-эффектами. В документации, явно об этом не написано.

Возвращаясь к нашей задачи. 5 секунд будет потрачено при вычислении первого аргумента и 10 секунд для второго. Итого: 15 секунд.

Как с этим бороться? Использовать альтернативные функции. Например, COALESCE.
О ней я расскажу более подробно в следующих постах.

#решениезадачи #функции #nvl #coalesce
Канал с отзывами 🗣

Всем привет!

Когда-то далеким январем 2020-го, я купил курс по созданию Telegram-каналов (да, я тоже обучаюсь и тоже покупаю обучение).

В одной из глав мануала было примерно следующее: “заведите второй канал и добавляйте в него отзывы по вашим услугам, обратную связь и т.д. Он будет полезен”.
Я тогда на это подзабил, ибо все казалось туманным и, исходя из принципа “бережливого производства”, смысла этим тогда заниматься не было.

Вернемся в настоящее. Прошло почти 2️⃣ года с момента основания канала. Много чего было сделано - курс по PL/SQL, интенсив по секционированию, частные консультации. Получена обратная связь по YouTube и Telegram-каналам. А я так и не сделал канал-отзовик... 🤦🏻‍♂️

“Пора исправляться” подумал я и потратил воскресенье на его создание.
Можно сходить сюда и посмотреть, чего там Денис насобирал 😉

Это пока не все отзывы, но с чего-то надо начинать. Буду постепенно публиковать.

#отзывы
👍51
Задача
Дана функция - sleep. Просто засыпание на N секунд с возможностью использования как функции в SQL и PL/SQL. Всегда возвращается “1”.

create or replace function sleep(p_sec number) return number
is
begin
dbms_session.sleep(p_sec); -- 18+
-- dbms_lock.sleep(p_sec); -- до 18
return 1;
end;
/

Выполняется такой запрос:
select coalesce(sleep(5), sleep(5), sleep(5))
from dual;

За сколько секунд он выполнится?

Рекомендую не повторять этот код, а подумать и выбрать ответ. И только после этого, повторить в СУБД и проверить себя 😉


⚠️ Завтра будет анонс нового потока на курс “Oracle PL/SQL.Основы”. А пока, можно почитать отзывы ребят с предыдущих потоков.

#задача
Друзья, всем привет!

Рад сообщить, о старте третьего потока курса “Oracle PL/SQL.Основы”.

Он будет полезен: QA-инженерам, разработчикам, аналитикам.

Основная цель: научить вас читать чужой и писать свой PL/SQL-код, достаточный для современной разработки и закрытия рабочих задач.

🔹22 видео с теорией;
🔹24 практики = единый проект;
🔹13 онлайн встреч в Zoom с разбором вопросов;
🔹закрытый телеграм-канал;
🔹старт в январе 2022.

Практика построена таким образом, чтобы вы с нуля, шаг за шагом, создали API на PL/SQL для прототипа платежной системы. Начав с анонимных блоков вы закончите своим мини-фреймворком для Unit-тестирования. Пример.

Подробности и программа - здесь. Отзывы - здесь.

Для тех кто заинтересован, но пока не уверен, я создал промо-группу курса, в которой буду размещать подробности, отрывки с занятий, отвечать на вопросы (да вы можете их сразу задавать) и даже встретимся онлайн. Залетайте!

P.S. Студентам, успешно закончившим курс, будет бонус в виде рекомендаций при трудоустройстве в Qiwi 🐥
Задача: постановка в посте вторника.

Решение:
Функцию COALESCE я упомянул еще на прошлой недели в качестве альтернативы NVL. Однако, опрос вторника немного удивляет 😉

Основные отличия от NVL

1️⃣ Функция может принимать более двух аргументов.

2️⃣ Используется короткозамкнутое вычисление (short-circuit evaluation), т.е. аргументы вычисляются по мере надобности.

3️⃣ В coalesce все аргументы должны быть одного типа. NVL - неявно преобразует тип второго аргумента к первому. Есть особенности, см. доку ⚠️

4️⃣ Функция относится к ANSI SQL, может быть использована в других РСУБД. NVL - чисто Оракловая поделка.

5️⃣ Отличия в выполнении запросов.

Согласно п.2. правильный ответ: 5 секунд.
Функция не будет вычислять ни второй, ни третий аргументы, т.к. первый аргумент не null.

Дополнительная задачка на подумать: выполнится или нет?
select nvl(10, 'abc') from dual;


В новом году, можно начать изучать PL/SQL с опытным наставником. Переходите на темную сторону 😈

#решениезадачи #функции #nvl #coalesce
👍6
Принципы построения backend-приложений с СУБД Oracle

Коллеги, всем привет!

Существует несколько принципов построения приложений с использованием БД. С разной толщиной программного слоя в БД или его отсутствия и т.д.

Хочется показать вам один из вариантов построения приложений. Рассмотрим: 3х-звенку, без ORM, с бизнес-логикой в middleware, с легким налетом технического API в БД.

Сеньёров, думаю, не удивлю, а джунам и мидлам, будет полезно послушать про разные подходы. Причем, не только разработчикам.

Можно было бы, конечно, запилить видос, но хочу попробовать что-то иное.
Это будет “живое” Online-выступление с демонстрацией, минут на 30-40 + вопросы. Формат для меня немного новый, но попробовать стоит.

Вдруг приживется, тогда можно было бы собираться раз в месяц, например, и рассказывать о какой-нибудь теме.

По времени: ~27.12 19:30-20:30.
Это будет Zoom-конфа и, возможно, трансляция в Youtube (еще не пробовал).

Голосовалочка - нужно это кому-то или нет ⬇️

Всем хороших выходных! 👍

#мини_конфа
Друзья, всем привет!

В прошлую пятницу, я анонсировал мини-лекцию.
Тема: "Принципы построения backend-приложений с СУБД Oracle"

Я расскажу о распространенных методах построения приложений в связке с СУБД.
Детально, на примере, рассмотрим: трехзвенную архитектуру, без ORM, с бизнес-логикой в Java-приложении (middleware/backend) с легким налетом технического API в БД.

Показанные принципы в лекции используются у нас в компании на некоторых проектах. Этот же принцип я использую в своем курсе "Oracle PL/SQL.Основы".

🔸
Начало: 27.12.2021 19:30(МСК)
🔸 Ссылка: https://qiwi.zoom.us/j/91654869378?pwd=MlkxY

А будет ли запись?
Записывать буду 100%. Пока не знаю, залью ли на общее обозрение.
Трансляции на youtube не будет.
Если не хотите ставить Zoom, можно воспользоваться Web-клиентом.

До встречи!

#мини_конфа
Друзья, всем привет!

Вчера прошла мини-лекция "Архитектура backend-приложений в связке с СУБД Oracle".

Было интересно. Всем кто пришел - респект 👍

По многочисленным просьбам залил видео встречи.
На мой взгляд, онлайн присутствие интересней, но если другого выхода нет... смотрите на ускорении x1.25 😉

Было бы классно получить обратную связь - зашел такой формат или нет, какие темы интересны и др.
Если формат зашел - можем как-нибудь повторить 🎓

__
Шанс принять участие в курсе "Oracle PL/SQL.Основы" схлопнется 31.12 со звуком профуканной возможности. Успевайте 🤓

#мини_конфа #архитектура
👍1
Друзья, всем привет!
Философский пост.

1️⃣ Вероятно, в детстве, а может и сейчас, вы играли в ролевые игры (RPG). В самом начале ваш персонаж голенький хиленький с уровнем развития => 0. Чем дольше вы его прокачиваете, тем лучше становится броня, навыки, умения. Квесты становятся интересней, рутина исчезает, игровая жизнь ярче.
Так и в реальной жизни. Чем большим набором hard и soft-скилов мы обладаем, чем выше наша квалификация, тем больше возможностей открывается перед нами. Например, подтянули навыки разговорного английского – открылся новый бонусный уровень «работа за рубежом».

2️⃣Работодатели готовы давать плюшки, бонусы, зарплату повыше, если вы несете пользу. Предположим вы QA-инженер. Еще вчера вы не понимали, что происходит в PL/SQL-слое, но уже через три месяца, вы начали в этом разбираться. Разве это не сигнал вашему менеджеру, что вы растете, а вместе с ростом ваше время стало стоить дороже? Конечно. А если нет? То может пора поменять компанию, где кормят лучше? И вы можете себе это позволить, ведь вы обладаете знаниями.

3️⃣ Я уже рассказывал на встрече про аналитика из одной ритейловой сети. Повторюсь. Мы начали заниматься в марте в индивидуальном режиме, потом он посетил все мои программы. Парень - трудоголик, жаден до знаний. В своем роде он уникален. Аналитик, который пишет сложные SQL-запросы и PL/SQL-код. Продвигает unit-тестирование. Знает зачем нужно секционирование. Чем отличается OLTP от DWH. Любое адекватное руководство это заметит. И его заметили. Создали под него целый отдел и существенно подняли з/п. Стоимость обучения уже отбито много раз.

4️⃣ Самое важное вложение, не в новый айфон и не в новый ТВ большего размера. На мой взгляд, здоровье и развитие – это важнее, чем все материальные побрякушки. Развиваясь, вы делаете ваше время дороже. Как ни крутите, мы все продавцы времени. Мы его постоянно меняем на деньги. Если можно менять дорого, зачем менять дешево?

5️⃣ И еще один момент. Можно самому долго копаться разбираться в теме, но когда есть ментор, процесс обучения становится на порядок проще по разным причинам.

Портал перехода на новый уровень открыт » здесь «
Завтра в 23:59 он закроется со звуком профуканной возможности 😉
👍2