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

Всем привет! Помогите плз разобраться. Есть такой блок кода: DO $$ BEGIN WITH cte

AS (
SELECT cte.student_id
FROM students cte
WHERE student_id > 41
ORDER BY cte.student_id ASC
LIMIT 10
)
UPDATE students st
SET modify_time = create_time + interval '1 second'
FROM cte
WHERE cte.student_id = st.student_id
AND st.modify_time < st.create_time;
ROLLBACK;
END;
$$
-- students.student_id - primary key,
-- по полям modify_time и create_time подходящих индексов нет.

Вопрос: как проще всего с минимальным чтением узнать последний id из cte?
В дальнейшем я хочу сделать переменную, чтобы в цикле update'ить записи. И чтобы каждый update был в одной транзакции, так как не хочется надолго блочиить таблицу. Возможно даже некоторую паузу поставить между итерациями.

6 ответов

11 просмотров

>опрос: как проще всего с минимальным чтением узнать последний id из cte? SELECT max(id) FROM cte >В дальнейшем я хочу сделать переменную, чтобы в цикле update'ить записи. Выглядит как отрезание хвоста по частям. Не, вообще подход с делением большых update на какие-то маленькие -- имеет право на жызнь. Но с переменными и по одной -- это ещё хужэ, чем какой-нибудь миллиард записей сразу переписать.

Ринат-Сафаров Автор вопроса
Ilya Anfimov
>опрос: как проще всего с минимальным чтением узна...

Не по одной) Я планировал найти оптимальное значение для limit в cte. Может быть будет 10 итераций, а может быть 100.

Ринат Сафаров
Не по одной) Я планировал найти оптимальное значен...

Главное -- не забудьте, что в РСУБД любая транзакцыя имеет право навернуться.

Ilya Anfimov
>опрос: как проще всего с минимальным чтением узна...

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

Ринат Сафаров
Не по одной) Я планировал найти оптимальное значен...

магическое число 500, как и в оракле, не знаю с чем связано )

жуть конечно. а в чем смысл кода?

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

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

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
70
Здравствуйте. Задача состоит в том, чтобы сделать real-time чат в мобильном приложении. После передачи сообщения пользователем через веб-сокеты, для основного и долговременног...
🐾
5
Всем доброго дня, ребят подскажите пожалуйста, если в курсе по ассемблеру используется MASM32, могу ли я использовать FASM? В чем явная разница и будет ли у меня все работать?
Botsman
17
падает джоба хотя уже была собрана на соседнем namespace, куда капать? │ │ Copying blob sha256:2fa066caddb8f09a71082b03aa43046f79346a01d9c89e06a1f508bb1207dba5 427 │ │ Copyin...
Andrei St
1
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
25
Книга Юрова В.И пойдёт для обучения?
Botsman
24
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Люди добрые, помогите с идеями, потому что свои закончились. У клиента падает софтина в момент инициализации модуля OtlEventMonitor на RegisterWindowMessage('Gp/OtlTaskEvents/...
Михаил Усков
7
Тут просто дело в том, что я не могу сейчас дать такие подробности из за того что рассчитать это всё нереально. Этого проекта который я хочу сделать ещё даже не существует) И ...
🐾
8
> Примечательно, что новый владелец удаляет из GitHub любые жалобы, указывающие на подозрительную активность или смену владельца, и, видимо, рассчитывает на то, что пользовате...
Alex Sherbakov
2
Карта сайта