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

Всем привет, подскажите если я делаю вставку в столбец

dt DateTime на который включен ORDER BY dt, а не tuple() то значит ли это, что при выборке реальный порядок событий вставки может нарушиться? Не перетасует эта сортировка одинаковые секунды?

24 ответов

26 просмотров

если у вас одинаковое время, то каким образом БД должна понять какой порядок у этих строк? 2021-12-28 18:20:13 2021-12-28 18:20:13 2021-12-28 18:20:13

Максим-Броня Автор вопроса
Konstantin Sevastianov
если у вас одинаковое время, то каким образом БД д...

а ей и не надо понимать ) нужно просто не менять этот порядок ))

Максим Броня
а ей и не надо понимать ) нужно просто не менять э...

а если все 3 записи ушли на 3 разных шарда, в каком порядке данные должны отдаваться обратно?

Максим-Броня Автор вопроса
Konstantin Sevastianov
а если все 3 записи ушли на 3 разных шарда, в како...

в том порядке в котором ушли... с учетом конечно задержки на отправку

DateTime MATERIALIZED now()

SQL в общем случае таких гарантий не дает если вставляете в одном insert и на одну реплику и не в distributed Таблицу в которой какщй нибудь sharding_key rand() то оно в один блок попадет скорее всего и на вход конвейера пойдет в том порядке как записалось но потом внутри конвейера что угодно можте произойти

Максим-Броня Автор вопроса
Максим-Броня Автор вопроса
Konstantin Sevastianov
задавайте явный порядок на стороне клиента

так на стороне клиента как раз все ок.. боюсь что перепутается при выборке

Максим Броня
так на стороне клиента как раз все ок.. боюсь что ...

так пронумеруйте события, добавьте столбец event_num и инкрементируйте его

Slach [altinity]
и что это даст?

порядок вставки, можно DateTime64

Дмитрий К
порядок вставки, можно DateTime64

для одного блока одинаковое время всем записям будет проставлено насколько я понимаю

Максим-Броня Автор вопроса
Дмитрий К
в блоке, да, нужно вычислять порядок строки

спасибо, в итоге сделал вот такую вычислялку ,__tid Int64 MATERIALIZED toUnixTimestamp64Milli( now64() ) * 1000000 + rowNumberInAllBlocks() ... сейчас еще потестирую на скорость работы

Максим Броня
спасибо, в итоге сделал вот такую вычислялку ,__ti...

хоть бы объяснили зачем вам "порядок строк" есть сильное подозрение что это не нужено

Максим Броня
спасибо, в итоге сделал вот такую вычислялку ,__ti...

вдогонку fromUnixTimestamp64Milli(toUnixTimestamp64Milli(now64()) + rowNumberInAllBlocks())

Максим-Броня Автор вопроса
Slach [altinity]
хоть бы объяснили зачем вам "порядок строк" есть с...

мне нужно хранить события в строгом порядке.. если порядок поменяется, что трудно будет потом понять как и что происходило в реальности ) особенно если это какой-то разбор полетов или отладка сложной ошибки

Максим Броня
мне нужно хранить события в строгом порядке.. есл...

мне казалось это надо делать на стороне клиента, что если вы вставляете большим куском и КХ разбивает данные на несколько блоков?

Максим Броня
мне нужно хранить события в строгом порядке.. есл...

К данным прилепите их порядок и все будет круто

Максим-Броня Автор вопроса
Konstantin Ilchenko
мне казалось это надо делать на стороне клиента, ч...

вот я и пытаюсь понять.. если он разбивает на блоки.. может он их последовательность вставки нарушить?

Максим Броня
мне нужно хранить события в строгом порядке.. есл...

Если источников несколько машин Каждый со своим clock И у вас время синхронизировано только через ntp то там порядок только внутри одной машины Для двух может незначительно нарушиться если событий сотни тыщ в секунду

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта