SQL Portal | Базы Данных
14.4K subscribers
611 photos
83 videos
41 files
506 links
Присоединяйтесь к нашему каналу и погрузитесь в мир баз данных

Связь: @devmangx

РКН: https://clck.ru/3H4Wo3
Download Telegram
Media is too big
VIEW IN TELEGRAM
Введение в PostgreSQL

00:37 Что такое PostgreSQL
02:39 Основные свойства
07:32 История развития
10:50 Форки PostgreSQL
21:24 Цикл разработки
29:05 Новые возможности

📹 Cмотреть: тык

👉 @SQLPortal | #видео
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7🔥5🌚1
Удаление дубликатов

Используйте ROW_NUMBER() с PARTITION BY user_id и ORDER BY created_at, чтобы сохранить только последнюю запись и удалить старые дубликаты.

Альтернатива — DISTINCT. Идеально для отслеживания уникальных пользователей или транзакций.

👉 @SQLPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍12🔥5
DataHub: веб-песочница для тех, кто изучает SQL

Читать: клик

👉 @SQLPortal | #статья
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6🔥1
Как найти значения, которых нет в другой таблице SQL?

При работе с базами данных часто нужно найти записи, отсутствующие в другой таблице. Для этого используются:

Способы поиска:
LEFT JOIN + WHERE IS NULL – выбираем строки без совпадений
NOT IN – фильтруем значения, которых нет в подзапросе
NOT EXISTS – проверяем отсутствие соответствующих записей

Что использовать? 👇

LEFT JOIN IS NULL – если таблицы большие и нужно фильтровать по нескольким полям
NOT IN – просто, но не работает с NULL
NOT EXISTS – подходит для подзапросов и сложных условий

Какой метод чаще используете? 🤔

👉 @SQLPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
👍12🔥41
Media is too big
VIEW IN TELEGRAM
Сортировка в SQL

00:00 Сортировка в SQL
01:50 Порядок сортировки: ASC, DESC
03:19 Совместное использование сортировки и фильтрации
04:21 Ограничение количества выбираемых строк
05:36 Сортировка по нескольким столбцам
06:46 SQL как английский
08:34 Итоги

📹 Cмотреть: тык

👉 @SQLPortal | #видео
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8🔥4
This media is not supported in your browser
VIEW IN TELEGRAM
Хотите разбить существующую таблицу на разделы в Oracle Database?

Начиная с версии 12.2, вы можете сделать это с помощью:

ALTER TABLE ... MODIFY PARTITION BY ...


А начиная с версии 23ai, можно преобразовать её обратно в неразделённую с помощью:

ALTER TABLE ... MODIFY NONPARTITIONED


👉 @SQLPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥4👍2
Уровни изоляции транзакций в PostgreSQL, MySQL, MSQL, Oracle с примерами на Go

Читать: клик

👉 @SQLPortal | #статья
Please open Telegram to view this post
VIEW IN TELEGRAM
👍3🔥1
Почему лучше использовать COUNT(1) вместо COUNT(*) в SQL?

При работе с большими таблицами в SQL важно учитывать производительность запросов.

COUNT(*) – в чем подвох?

Оператор COUNT(*) учитывает все столбцы таблицы, проверяя каждую строку. Хотя он возвращает правильное количество записей, обработка может занимать больше ресурсов, особенно в огромных таблицах.

COUNT(1) – оптимизированный вариант

COUNT(1) использует только первый столбец и не анализирует все остальные, что снижает нагрузку на базу данных. Это может ускорить выполнение запроса.

👉 @SQLPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍23🤔5
Media is too big
VIEW IN TELEGRAM
Практика по SQL: объединение таблицы с самой собой (SELF JOIN)

0:00 Условия задачи
2:35 Создание таблицы для экспериментов в PostgreSQL
3:33 Объединение таблицы с самой собой (SELF JOIN)
6:27 Условие фильтрации
7:17 Проверка решения
8:31 Итоги

📹 Cмотреть: тык

👉 @SQLPortal | #видео
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10
SQL-Translator – визуализируй SQL-запросы мгновенно!

Устал разбираться в сложных SQL-запросах? SQL-Translator преобразует их в наглядные схемы, помогая быстро понять структуру данных

🟡 Парсит SQL-запросы и визуализирует их
🟡 Поддерживает PostgreSQL, MySQL, SQLite и другие БД
🟡 Работает прямо в браузере – ничего устанавливать не нужно!

Попробуй сам: здесь

👉 @SQLPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7🌭3🔥2
Миграция базы данных происходит, когда вы вносите изменения в базу данных.

Это может быть изменение схемы таблицы, обновление данных в записи и так далее.

В этом уроке Доминик научит вас работать с миграциями MongoDB с помощью ts-migrate-mongoose.

Ссылка: клик

👉 @SQLPortal | #статья
Please open Telegram to view this post
VIEW IN TELEGRAM
👍32🔥1
Полезная фишка в SQL: COALESCE() — замена NULL значений на дефолтное значение.

Часто в базах данных встречаются поля с пустыми значениями (NULL). Но как их обрабатывать? 🤔

Тут на помощь приходит функция COALESCE(), которая возвращает первый ненулевой аргумент из списка. Это суперудобно для замены NULL на что-то полезное!

👉 @SQLPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
👍15🔥3🌚2
Media is too big
VIEW IN TELEGRAM
Основы работы в PL/SQL Developer

В этом видеоуроке автор подробно разбирает основы работы в удобной, функциональной и быстрой визуальной среде разработки PL/SQL Developer, а также ее основные преимущества и недостатки.

📹 Cмотреть: тык

👉 @SQLPortal | #видео
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🔥2🌚1
Media is too big
VIEW IN TELEGRAM
IT Hero — это твой лучший друг для подготовки к техническим собесам

Тут не просто теоретические вопросы, а реальные задачи на кодинг, алгоритмы, базы данных, сети, безопасность и многое другое.

Раньше приходилось штудировать кучу ресурсов, а теперь всё в одном месте: заходишь, выбираешь тему, решаешь задачи, подтягиваешь слабые места и становишься жестким технарём. 👍

Попробуй сам: здесь

👉 @SQLPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5👀4🔥3
Хеш-индексы в PostgreSQL: быстрый поиск или скрытые проблемы?

Ссылка: клик

👉 @SQLPortal | #статья
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🔥1
SQL Фишка: Генерируемые столбцы

Хватит вручную пересчитывать данные! SQL умеет хранить вычисляемые значения автоматически.

Как делать НЕ НАДО:

Вы храните в таблице orders сумму заказа и обновляете её вручную? Это потенциальный источник багов!

UPDATE orders SET total = price * quantity WHERE id = 1;


Можно забыть обновить поле → данные сломаются.

Как делать ПРАВИЛЬНО:

Используем генерируемый столбец:

CREATE TABLE orders (
id INT PRIMARY KEY,
price DECIMAL(10,2),
quantity INT,
total DECIMAL(10,2) GENERATED ALWAYS AS (price * quantity) STORED
);


Теперь total всегда автоматически содержит правильное значение.

👉 @SQLPortal
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥14👍8
Media is too big
VIEW IN TELEGRAM
Проектирование баз данных

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

📹 Cмотреть курс: тык

👉 @SQLPortal | #курсы
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8🔥1