72 похожих чатов

Всем привет! есть такая процедура CREATE OR REPLACE PROCEDURE generate_partition(_begindate

date, _enddate date)
AS
$$
DECLARE
_sql text;
loopdate date DEFAULT _begindate;
BEGIN
IF _begindate > _enddate THEN
RAISE EXCEPTION '_begindate should smaller than _end_date';
END IF;
IF _begindate is null or _enddate is null THEN
raise exception '_begindate and _enddate cannot be null';
end if;
while loopdate <= _enddate
LOOP
_sql := 'CREATE TABLE rpp_order_partition_'
|| to_char(loopdate, 'YYYYMMDD')
|| ' partition of order for values in ( '''
|| loopdate || ''')';
RAISE NOTICE '_sql: %', _sql;
EXECUTE _sql;
SELECT (loopdate + interval '1 day')
INTO loopdate;
END LOOP;
END
$$
LANGUAGE plpgsql;
которая генерирует партиции по дням, название сгенеренной партиции получается вида
rpp_order_partition_20220617
, но проблема в том, что поле по которому создана партиция имеет формат
2022-06-17 12:00:00.000000
и при вставке новой записи партиция не может быть найдена, т.к форматы дат разные, подскажите, пожалуйста, как это можно исправить? нужно чтобы при вставке записи с датой вида
2022-06-17 12:00:00.000000
она попадала в партицию
rpp_order_partition_20220617
, БД postgresql

5 ответов

15 просмотров

> т.к форматы дат разные Не так как "форматы дат разные", а так как ваша дата преобразована в формат этого поля (timestamptz, видимо, кстати, зачем мне его угадывать?) -- и получилась ровно одна микросекунда в полночь этой даты. А указывать надо интэрвалы времени. (Точнее, конечно, не надо. Поскольку партицыонирование в postgres не очень хорошэе, и навредить можэт очень легко. Потому в подавляющем большынстве случаев новички только создают себе проблемы попыткой партицыонировать postgres).

Михаил Регуш- Автор вопроса
Ilya Anfimov
> т.к форматы дат разные Не так как "форматы дат ...

да, верно, формат поля timestamp, забыл на это указать не очень понял про микросекунды, в сообщении дату 2022-06-17 12:00:00.000000 указал для примера, она может иметь любой вид - 2022-06-17 12:35:08.000000

Михаил Регуш- Автор вопроса
Михаил Регуш
да, верно, формат поля timestamp, забыл на это ука...

>формат поля timestamp Смените лучшэ на timestamptz. https://wiki.postgresql.org/wiki/Don%27t_Do_This#Don.27t_use_timestamp_.28without_time_zone.29 >указывать интервалы времени где? В create table.

Похожие вопросы

Обсуждают сегодня

Я не понимаю, это троллинг или что? Швабрика поддерживают, который буквально пишет на ассемблере взаимодействия с винапи. Я это ещё написал загрузчик и хоть что-то изучаю в о...
Shadow Akira
6
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Всем привет. Хотел бы написать для себя свою ос. Причины: 1) нужен опыт в чем-то 2) будет меньше весить 3) свое, но там будут свои задумки Я понимаю что нужно писать для всег...
Shadow Akira
18
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
3
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Ночной вопрос остался в силе. Кто-нибудь может подсказать как preview fields расширить в Rainlab.User?
Даниил
3
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Парни, а как можно показывать поля формы с одинаковым неймингом в бекенде в зависимости от разрешений, попробовал выставить permissions, но ругается на duplicate key. Может мо...
Racoon Mitya
1
Карта сайта