Исключите перекрывающиеся события (начало/окончание) с учетом места проведения_id

У меня есть следующая таблица:

events
- id
- venue_id
- starts_at
- ends_at

Я нашел это ограничение https://www.postgresql.org/docs/current/sql-createtable.html#SQL-CREATETABLE-EXCLUDE, но я не уверен, что понимаю, как я могу использовать его, чтобы предотвратить создание перекрывающихся событий при учете venue_id, чтобы могли быть перекрывающиеся события, но не для одних и тех же мест.

Например:

EXCLUDE USING gist (tsrange(starts_at, ends_at) и как-то учитывать местонахождение_id

Спасибо

Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
0
0
10
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вам нужно объединить «перекрытие» диапазона временных меток с оператором = в venue_id

alter table events 
   add constraint no_overlapping_events
   exclude using gist (venue_id with =, tsrange(starts_at, ends_at) with &&)

Обратите внимание, что для этого требуется расширение bree_gist из-за использования оператора =.

Благодарю вас! Я обновлю свою базу данных, чтобы включить CREATE EXTENSION btree_gist;

Askskd Rieid 17.05.2022 18:31

Другие вопросы по теме