Skip to content

Новости за 2025-05-24 - 2025-05-30

§ Лидеры недели

	Участник		w_sel	all_sel	select	dml	Всего	Рейтинг
Новиков С.В. (@Ser589QA) 8 89 18 0 18 366
Вольхин С.А. (Sergei Volkhin) 7 71 17 15 32 437
А Б.В. (dsf4wsfw) 14 14 17 0 17 5161
GMM (gmm_sql) 10 11 14 0 14 5335
Матвеев М. (Матвеев Максим) 5 45 10 0 10 1460
Bulyakarov S. (Sa1avat) 5 130 7 0 7 174
Иванов К.А. (Монсун) 2 46 4 0 4 1114

§ Претенденты на попадание в TOP 100

Рейтинг	 Участник (решенные задачи, время в днях)
174 Sa1avat (130, 103.199)
345 AstroZomb (83, 4507.944)
366 @Ser589QA (89, 105.854)

Continue reading "Новости за 2025-05-24 - 2025-05-30"

Улучшение функциональности журнализации с помощью новой функции JSON в PostgreSQL 15

Пересказ статьи Maly Mohsem Ahmed. Enhancing Logging Functionality with PostgreSQL 15’s new JSON Logging Feature


В PostgreSQL появилась новая замечательная функция: журнализация JSON. Хотя журналы JSON занимают больше места, чем журналы в традиционных форматах, они предлагают значительные улучшения, такие как облегчение парсинга и обработки. Эта возможность появилась, начиная с PostgreSQL 15.

Конфигурирование журнализации JSON


Чтобы включить журнализацию JSON, вам необходимо настроить файл postgresql.conf следующим образом:

log_destination = 'jsonlog'  # Доступные значения: сочетание stderr, csvlog, jsonlog, syslog и eventlog (независимо от платформы).
logging_collector = on # Требуется для захвата stderr, jsonlog и csvlog в файлы журнала. Это должно быть включено для csvlog и jsonlog.

С этими настройками вывод из журнала может выглядеть следующим образом:
Continue reading "Улучшение функциональности журнализации с помощью новой функции JSON в PostgreSQL 15"

Использование hstore для хранения неструктурированных данных в PostgreSQL

Пересказ статьи DbVisualizer. Using hstore for Storing Unstructured Data in PostgreSQL


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

Что такое hstore в PostgreSQL?


hstore позволяет сохранять пары ключ-значение в строковом формате в одном столбце. Эта гибкость идеально удовлетворяет пожеланиям пользователей, хорошо подходит для хранения конфигурационных параметров или метаданных. Вот простой пример:

ALTER TABLE users ADD COLUMN metadata hstore;

Continue reading "Использование hstore для хранения неструктурированных данных в PostgreSQL"

Новости за 2025-05-17 - 2025-05-23

§ Лидеры недели

	Участник		w_sel	all_sel	select	dml	Всего	Рейтинг
Bulyakarov S. (Sa1avat) 12 125 27 0 27 179
Вольхин С.А. (Sergei Volkhin) 14 64 24 13 37 610
Иванов К.А. (Монсун) 4 44 8 16 24 1151
Noname N.N. (Artem74) 6 7 8 0 8 2909
Firsin A.A. (xlam) 4 4 5 0 5 7430
Ешану М.В. (MaxEshanu) 4 4 5 0 5 7526

§ Изменения среди лидеров рейтинга

Рейтинг	Участник (решенные задачи)
29 gennadi_s (169)
Continue reading "Новости за 2025-05-17 - 2025-05-23"

Улучшение поиска текста в базе данных

Пересказ статьи Hafidz Mahrus. Enhancing Database Text Search


В мире реляционных баз данных MySQL является одной из наиболее популярных, благодаря легкости использования и масштабируемости. В то время как MySQL замечательно себя показывает в хранении и извлечении структурированных данных, она может быть не так хороша при выполнении полнотекстового поиска в больших объемах неструктурированного текста. И тут вступают в действие возможности полнотекстового поиска в MySQL.

Полнотекстовый поиск является мощным средством в MySQL, которое позволяет эффективно выполнять поиск текста в больших наборах неструктурированных данных. В этой статье мы подробно исследуем полнотекстовый поиск в MySQL, включая его функциональность, синтаксис, оптимизацию производительности и реальные случаи использования.

Continue reading "Улучшение поиска текста в базе данных"

Функции JSON_OBJECTAGG и JSON_ARRAYAGG в SQL Server

Пересказ статьи Koen Verbeeck. SQL Server JSON Functions JSON_OBJECTAGG and JSON_ARRAYAGG


Мне необходимо построить JSON из данных, находящихся в базе данных, но оказалось, что существующая конструкция FOR JSON PATH ограничена, когда данные не находятся в одной единственной строке, а разбросаны по множеству строк. Есть ли другой метод обработки данных JSON в SQL Server? Узнайте, как использовать новые функции JSON в SQL Server - JSON_OBJECTAGG и JSON_ARRAYAGG.

Были введены две новые функции T-SQL для создания документов JSON из имеющихся данных: JSON_OBJECTAGG и JSON_ARRAYAGG. Обе являются агрегатными функциями, которые помогают создать представления JSON из данных, хранящихся в множестве строк.

Здесь мы познакомимся с обоими функциями. На момент написания статьи эти функции доступны только в Azure SQL DB, Azure SQL Managed Instance и Fabric SQL Database. Эти функции должны быть включены в следующие версии SQL Server. Continue reading "Функции JSON_OBJECTAGG и JSON_ARRAYAGG в SQL Server"

Замена курсоров SQL операциями на основе множеств - OUTPUT и MERGE

Пересказ статьи Jared Westover. Replace SQL Cursors with Set Based Operations – OUTPUT and MERGE


Курсоры имеют плохую репутацию в SQL Server, и вполне залуженную. Они находят свое применение в таких областях, как выполнение задач по обслуживанию баз данных. Я избегаю их, когда дело касается стандартного кода T-SQL. Проблемы производительности становятся заметными при работе с таблицами сколь-нибудь заметного размера. Если вы имеете за спиной более процедурный язык, бывает трудно думать не в терминах курсора. Но не беспокойтесь, есть надежда.

В этой статье я хочу сделать обзор типичного паттерна, который мы все видели. Он включает использование курсора или цикл WHILE для вставки или обновления данных. Начнем с того, чтобы разобраться, почему разработчик может по умолчанию начинать с курсора. Далее я построю типичный курсор для решения этой задачи. Затем мы разберемся, как можно быстрей достичь того же вывода с помощью операции на основе множеств.
Continue reading "Замена курсоров SQL операциями на основе множеств - OUTPUT и MERGE"

Что происходит при удалении столбца в таблице SQL Server? Где мое пространство?

Пересказ статьи Cláudio Silva. What happens when we drop a column on a SQL Server table? Where's my space


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

Операция с метаданными


Удаление столбца является логической операцией с метаданными, а не физической. Это означает, что данные не удаляются/перезаписываются при этом действии. Если говорить об удалении данных (записей), то как упоминает здесь Пол Рэндал:

«стоимость этого будет отложена для вставляющих, а не для удаляющих».
Continue reading "Что происходит при удалении столбца в таблице SQL Server? Где мое пространство?"

Новости за 2025-05-03 - 2025-05-09

С Днем Победы!


§ Популярные темы недели на форуме

Топик		Сообщений	Просмотров
25 (Learn) 2 9
780 (SELECT) 2 10
101 (SELECT) 2 5

§ Авторы недели на форуме

Автор		Сообщений
sorokin andrei 4
pegoopik 2

§ Изменения среди лидеров рейтинга

Рейтинг	Участник (решенные задачи)
29 gennadi_s (168)

Continue reading "Новости за 2025-05-03 - 2025-05-09"

Понимание разницы в производительности при добавлении столбцов в PostgreSQL

Пересказ статьи Hagen Hübel. Understanding the Performance Difference in Adding Columns in PostgreSQL


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



Вопрос


Представьте, что у вас есть большая таблица, содержащая десятки тысяч записей. Вы хотите добавить новый допускающий NULL-значения столбец без значения по умолчанию, а затем выполнить оператор UPDATE, чтобы установить для этого нового столбца заданное значение. Этот процесс занимает значительное время. Однако, если вы вместо этого добавляете новый столбец со значением по умолчанию, это не занимает так много времени. Почему имеет место такая разница в производительности?
Continue reading "Понимание разницы в производительности при добавлении столбцов в PostgreSQL"

Статические курсоры

Пересказ статьи Hugo Kornelis. Plansplaining part 30 – Static cursors


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

Тестовый запрос


В этой серии я буду придерживаться использования одного и того же тестового запроса, который выводит данные по продажам и товарам, которые были проданы в количестве более 10 единиц в пределах заданного диапазона заказов.
Continue reading "Статические курсоры"

Новости за 2025-04-26 - 2025-05-02

§ Учебник (sql-tutorial.ru) находится на реконструкции. Планируем в течение мая выложить новую версию. Извиняемся за доставленные неудобства.


§ Лидеры недели

	Участник		w_sel	all_sel	select	dml	Всего	Рейтинг
Иванов К.А. (Монсун) 11 25 18 0 18 2935
Паласухин Д.С. (Nitrinos) 6 34 11 0 11 1419
Ghitinomagomedov (gmansur88) 5 28 7 0 7 2644
Bulyakarov S. (Sa1avat) 1 102 4 0 4 237

Continue reading "Новости за 2025-04-26 - 2025-05-02"