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

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

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

24 ответов

16 просмотров

если у вас одинаковое время, то каким образом БД должна понять какой порядок у этих строк? 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 то там порядок только внутри одной машины Для двух может незначительно нарушиться если событий сотни тыщ в секунду

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

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

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Привет, запускаю werf в dind в k8s, получаю ошибку на этапе build/beforeSetup: /.werf/stapel/embedded/bin/bash: /.werf/scripts/5898bdfe5214357d3706b879cc8d3d78460fb379607cbd...
florius0
7
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Подскажите, можно ведь комбинировать запись данных в один и тот же Stream через TFileStream и через TCompressionStream поочерёдно? Ну т.е. часть данных мне нужно сжать, часть ...
notme
4
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Кстати на работу никто не хочет, слегка на Сшке подписывать? От 170к в месяц, под Москвой
Andrey Ermakov
6
Карта сайта