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

Добрый день. Вопрос про подходы к проектированию таблиц в clickhouse. В

данной СУБД планирую хранить протоколы работы последовательного запуска ряда программ.
Пусть протоколы имеют следующу структуру:
<root>
<computer name="my-pc">
<os>Windows 7</os>
<arch>x86</arch>
</computer>
<soft file="c:\my_program_1.exe" description="чудо-программа" version="0.1">
<process name="my_program_1" pid = "42" startDateTime="..." endDateTime="...">
<task name="open_file" status="true" message="Файл new_file.txt успешно открыт" />
<task name="write_to_file" status="true" message="Запись данных проведена" />
<task name="close_file" status="true" message="Файл закрыт" />
</process>
<process name="my_program_1" pid = "100500" startDateTime="..." endDateTime="...">
<task name="open_file" status="false" message="Файл new_file.txt не удалось открыть">
<error code="5" file="file_opener.cpp" function="f" line="99" tid="87"/>
</task>
</process>
</soft>
<soft file="c:\program.exe" description="программа" version="18.1">
...
</soft>
</root>
Стоит ли пытаться запихнуть все это в одну широкую таблицу, в которой данные по компьютерам, процессам и программам будут дичайше дублироваться
или правильнее разбить это на несколько таблиц (computer, soft, process, task, error) ?

Есть возможность использовать внешние справочники, в которых можно хранить названия программ и т.д. Есть ли в этом смысл?

1 ответов

3 просмотра

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

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

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

А чем вам питонисты не угодили?😂
.
79
Привет, запускаю werf в dind в k8s, получаю ошибку на этапе build/beforeSetup: /.werf/stapel/embedded/bin/bash: /.werf/scripts/5898bdfe5214357d3706b879cc8d3d78460fb379607cbd...
florius0
4
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
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Подскажите, можно ведь комбинировать запись данных в один и тот же Stream через TFileStream и через TCompressionStream поочерёдно? Ну т.е. часть данных мне нужно сжать, часть ...
notme
4
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ребят, кто сталкивался с тем, что Electron.js не разворачивает билд React.js-приложения? Голый body в чёрном цвете, как и должно быть, но остального - нет. Билд работает исп...
..
6
Карта сайта