JavaWhiteBook
92 subscribers
202 photos
4 videos
81 links
Привет!
Меня зовут Алексей. Мне 50.
Я третий год работаю java-разработчиком.
В этом канале я рассказываю про трудности-печали, с которыми сталкиваюсь, а также радости-победы, которые случаются.
Только практика, никакой теории, и очень простыми словами.
Download Telegram
Сообщение из Exel в Телеграмм.

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

Требовалось из экселя по нажатию кнопки отправить уведомление.

Создание бота и кода на VBA трудов не составило, однако не заработало...

В воскресенье удалось посидеть над задачей. Заставить работать MSXML2.XMLHTTP и еще пару каких-то вариантов не удалось.
В итоге написал bat-ник с параметрами, а в нем curl'ы. Честно говоря, первый раз за все время мне пригодились знания о curl.

Отдельная печаль была с энкодингом строки, т.к. в VBA встроенной функции нет.
Сначала хотел написать сам🤔, но потом быстро нашел место, где списать...

Сейчас все работает. С сегодняшнего дня начали пользоваться.
👍2🔥2
Эмодзи в сообщение телеграмм-бота

После вчерашней победы захотелось добавить красоты в сообщения телеграмм-бота 🌸

Из стандартного работает:
*жирное*
_подчеркивание_
~зачеркивание~
[текст_ссылки](ссылка)

Захотелось еще и смайликов повставлять.
Нашел замечательную табличку Emoji Unicode Tables, взял из нее код UTF-8 (только через %, а не \x) — и вот она красота!!!
🖥 Трудовые будни

Уже третью неделю занимаюсь одной задачей. Звучит достаточно просто - разработать сервис для автоматизации стрессового тестирования.

Что было понято после первых двух раз из прочитанного ТЗ:
1️⃣Надо получить данные, сложить их в свою базу.
2️⃣Сделать кое-какую агрегацию по этим данным и сохранить.
3️⃣Создать из заполненных таблиц csv файлы.
4️⃣Сохранить их в облако.
5️⃣Получить файл-сценарий, распарсить и сохранить в базу.
6️⃣Согласно сценарию сделать расчет.

Пока всё ещё сижу на первом пункте. 🫣
Структура работы с базой сервиса готова. Но вот получение — это просто ужас какой-то!

На данный момент нужны данные где-то из 20 таблиц с нетривиальными взаимосвязями. Причём просто взять и вытащить всё данные к себе не вариант. Данных ооочень много, количество столбцов в таблицах — около ста и выше, в некоторых более 150 миллионов записей.

Несмотря на ужас происходящего 🤣, до конца недели все-таки рассчитываю получить рабочий вариант п.1
🎓 Развитие

До НГ (2023) планирую:
🔹 доделать оглавление в заметках для собесов;
🔹 доделать поиск по оглавлению;
🔹 добавить в заметки вопросы по хиберу, jpa, и sql;
🔹 закончить курс по Oracle SQL;
🔹 пройти курс по SPRING от DMDew;
🔹 просмотреть курс(интенсив) по KAFKA от Spurs;
🔹 нарешать до 300 задач на leetcode, сейчас 173.

Мне кажется, что запланировано не так много и есть реальный шанс это всё сделать.

#plans
🔥5👍3
🖥 Трудовые будни

Продолжаю пилить сервис.

Для работы с BigDecimal сказали использовать библиотеку big-math.

Возникла необходимость запилить SQL (для MS) запрос данных со сроком давности, т.е., например, за последние 3 месяца.
Самым эффективным оказалось использовать функцию вычисления разницы дат
DATEDIFF (в_чем_мерить, дата, дата)

Чтобы не забыть, текущая дата - GETDATE()

Самое веселое — это приведение строки к дате, т.к. в базе дата хранится как строка yyyyMMdd
CONVERT(DATE, VARCHAR)

Кстати, у последней множество стилей, которые надо указывать кодом, а не паттерном.

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

Неделя только началась, а голова уже кругом. 🤯
А как началась ваша неделя?
👍4
🖥 Трудовые будни

Как и предположил ранее - возникли проблемы 😜

Первая - доступ к нескольким БД. Шеф ее решил за час, просто создав апи 🤘

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

Оказывается, данные, которые посылаю, вызывают в недрах стороннего сервиса 500-ю 🧨🧨🧨

Конечно, было бы приятнее увидеть что-то вроде 400 Bad Request, ну, да бог им судья 💩⚖️🎂

Буду завтра с утра мучить аналитика... 🎷🎻🎺

А пока пойду и выпью рюмку чаю что ли😜
👍2
🖥 Трудовые будни. Любовь дня - mapstruct.

Как говорил раньше, в моей текущей задаче достаточно толстые сущности. И основная печаль - большие конструкции по их созданию и апдейту. 🤧
Плюс, еще надо плодить сущности из имеющихся, но с небольшим уменьшением полей, а потом и их апдейтить. 🤮

Короче, этот бойлерплейт стал резать глаза. 📛 И тут я вспомнил про mapstruct. 💡

В разных источниках всегда звучало, что его используют для создания DTO из сущности, а мне надо сущность из сущности. 🤔
Вот я и решил, что если не получится, буду хоть дтохи клепать. 🙏🏻

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

Я получил, что хотел, но потом наткнулся на информацию, что можно еще делать и апдейтеры. Интересненько! 🧐

📅 Итог - буду переделывать все на маперы, и если получится, сделаю апдейты.

Кстати, если не надо мапить какое-то поле, то его можно заигнорить.

А вы как мапите и апдейтите толстые сущности?
Может есть что-то еще интересное?
👍6
🌐 Конференция

Вчера первый раз побывал на профильной конференции.
Скажу сразу - мне очень понравилось. 🔥

🔸 Первый доклад
Андрей Аркаев «Обновление Hibernate через боль»
О переезде на хибер 6.1.
В целом интересно, но проблема показалась далекой от меня.
Хотя схема апдейтов была интересной. 📌

🔸 Второй доклад
Илья и Фёдор Сазоновы «Добровольно-принудительный Spring»
ОЧЕНЬ КРУТО!!!
На ребят приятно смотреть и слушать.
Самым близким стало - "скажи привату НЕТ!!!" 👎 ☠️

Одна из проблем - тестирование приватных методов, потому что они тупо не мокаются. Ребята предлагают вынести их в отдельный бин!!! 🔥

У меня такой даже идеи не возникало!!!🤦‍♂️
Буду по-тихоньку в текущей задаче переписывать и добавлять тесты, благо, время позволяет. 🤪

Еще из приятного - подарили блокнотик, ручку, карандаш. 😉

Если есть желание посмотреть доклады - вот ссылочка
👍5🔥2
🖥 Трудовые будни

Это просто про меня!!!

После посещения конфы у меня родилась идея:
💡 мой поток сознания (код в сервисе) разделить на компоненты. 🤘

Занимался этим три дня. 🛠🛠🛠

Потом еще день запускал проект - NPE и им подобное лезло из всех щелей... 🐜🐜🐜 Хотелось убить автора кода 🤣

Вчера, наконец-то, добрался до простыни с изменениями и ошибками, которые надо исправить. 📜
Сразу прочувствовал и оценил текущую архитектуру 🔥
Место, где что-то надо проверить или исправить, находится быстро.
И т.к. вся логика находится в одном и единственном месте (что-то из SOLID), то и правится тоже быстро. 👍🏻
Плюс ко всему, к исправленному сразу можно написать тест. 🤠

А вам когда-нибудь приходилось переделывать свой же код?
🔥5
🖥 Трудовые будни

Вчера закончился испытательный срок. 🥳
Тортиков и подарков не было, хотя сказали, что подключат на след неделе к ДМС. 👍🏻

Продолжаю пилить свой сервис. 🧑‍💻☕️
Уже выложен на тестовые контура и работает. 🚀 Однако, аналитики и рисковики по мере проверки и анализа данных просят кое-что дорабатывать. 🙏🏻📜
Обычно это "кое-что" вылазит в несколько дней веселья.
🤦🏻‍♂️🤯🧑‍💻
До работы с облаком так и не добрался....

На работе архитекторы стали говорить о переходе на Spring Boot 3 и Java 17 🤔
С джавой все понятно, а с бутом - нет. Если кто уже переехал или пробовал, скажите, что там за подводные камни?

Как дополнение к выше сказанному - еще заговорили о Kotlin'е 😏
Не исключено, что придется развиваться в эту сторону.

С понедельника начинают внедрять Comunda 7. 📛
Вчера была вводная презентация, сегодня жду воркшоп.

А что у вас неинтересного?
👍6
Обо всем и сразу

🖥 Трудовые будни

На прошлой неделе решилась проблема с облаком: оказывается, косяки были на стороне девопсов 🤬
Никак не можем исправить все баги в бизнес-логике - опять нашли ошибку в вычислениях, буду сегодня править 🛠
Мой непосредственный начальник увольняется. 😭 Я, конечно, за него очень рад, но грустно - умный, спокойный и способный объяснять человек, и, кажется, такого сочетания качеств у оставшихся нет. Ну и просто близкий по духу человек...

🎓 Развитие

Как всегда, все пошло не по плану, хотя оглавление и поиск по нему сделал.
Дожимаю курс по SQL - осталось процентов тридцать. 🤪
За остальное даже не брался. 🤦🏻‍♂️
Но не все так плохо!

За декабрь поучаствовал в 2 адвентах: Календарь от Дианы 🎉 и Advent of code 2022 🔥
В первом очень хорошо вспомнил instanceof, узнал много интересного о внутрянке String, окончательно разобрался с Enum и познакомился с Record.
Во втором прочувствовал всю глубину поиска в ширину!!!
Ну и с ним я еще не закончил!!!
👍3
Всех с наступающим!!! 🎉

Этот год был богат на события. Эти события привели ко множеству перемен. Я, как адепт "глобального позитива", считаю, что все к лучшему 😜

А еще, у нас в семье есть традиция перед новым годом делать тазик имбирных печенек. 🍪🍪🍪
Одно из моих желаний, что бы это продолжалось как можно дольше. 🪄💫

Желаю всем здоровья и любви, молока и переченек!!! 🥳🥳🥳
🔥51👍1
🎓 Развитие

Медленно продолжаю продвигаться по по плану.
В курсе по SQL осталось два самых интересных раздела - Constraint и Index.
Так же удается найти время на легкие задачи с leetcode.

Последние заставили вспомнить алгоритм для поиска наибольшего общего делителя НОД (Greatest common divisor GCD), и найти красивую реализацию, прям как я люблю - с магией побитовых операций:

public static int gcd(int a, int b) {
if (b == 0) return a;
int i = a % b;
return gcd(b, i);
}
👍2