- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 PostgreSQL 表,我正在尝试将其转换为 TimescaleDB 超表。
该表如下所示:
CREATE TABLE public.data
(
event_time timestamp with time zone NOT NULL,
pair_id integer NOT NULL,
entry_id bigint NOT NULL,
event_data int NOT NULL,
CONSTRAINT con1 UNIQUE (pair_id, entry_id ),
CONSTRAINT pair_id_fkey FOREIGN KEY (pair_id)
REFERENCES public.pairs (id) MATCH SIMPLE
ON UPDATE NO ACTION
ON DELETE NO ACTION
)
当我尝试使用以下命令将此表转换为 TimescaleDB 超表时:
SELECT create_hypertable(
'data',
'event_time',
chunk_time_interval => INTERVAL '1 hour',
migrate_data => TRUE
);
我收到错误:
ERROR: cannot create a unique index without the column "event_time" (used in partitioning)
问题一:来自这篇文章
How to convert a simple postgresql table to hypertable or timescale db table using created_at for indexing我的理解是,这是因为我指定了一个唯一约束 (pair_id_fkey),它不包含我正在分区的列 - event_time。那是对的吗?
最佳答案
您正确理解 UNIQUE (pair_id, entry_id )
不允许从表创建超表,因为唯一约束需要包含分区键,即 event_time
在你的情况下。
UNIQUE (pair_id, entry_id, event_time)
是一种很常见的方法,但它允许插入您提到的具有不同时间戳的重复项。在插入过程中,它的性能将比选项 2 差。您可以替换 event_time
上的索引(这是您需要的,因为您在此列上进行查询,并且它是由 TimescaleDB 自动创建的)与 unique index ,所以你可以节省一点,例如,CREATE UNIQUE INDEX indx ON (event_time, pair_id, entry_id);
关于postgresql - 将 PostgreSQL 表转换为 TimescaleDB 超表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67582526/
我有一个系统,每 5 秒向 TimescaleDB 收集一次计数器数据。 汇总要求是: 对于超过 7 天的数据,粒度从 5 秒变为 1 小时 对于超过 30 天的数据,粒度从 1 小时下降到 1 天
我有一个系统,每 5 秒向 TimescaleDB 收集一次计数器数据。 汇总要求是: 对于超过 7 天的数据,粒度从 5 秒变为 1 小时 对于超过 30 天的数据,粒度从 1 小时下降到 1 天
SELECT timeseries_id, "timestamp"FROM enhydris_timeseriesrecord WHERE timeseries_id=6661 ORDER BY "t
我有一个包含几个表的简单数据库架构 (Timescaledb)。每个用户都有一个具有多个指标的主传感器,每个指标都有自己的表,其中包含 user_id 和时间戳。 架构 Table 1 |用户 ID
我刚刚尝试在 Ubuntu 20.04 的 minikube 中安装带有 Helm 的 timescaleDB Single。 安装后通过: helm install timescaledb time
给定时间序列范围,其值 v0-v5 以不规则间隔存储在 timescaledb 中。 v0 v1 v2 v3 v4 t0 - t1 - t2 - t3 - t4 - t5 选择了
根据docs: TimescaleDB支持在同一PostgreSQL实例中的不同数据库上具有不同的扩展版本。 我可以使用以下SQL命令获取实例的安装版本: SELECT extversion FROM
我正在尝试使用 TimescaleDB 扩展来计算一些连续聚合。我有这个工作正常的查询: SELECT distinct time_bucket('1 hour', entry_ts) as date
我有一些时间序列数据要导入到 TimescaleDB 中,作为超表中的 (time, item_id, value) 元组。 我已经创建了一个索引: CREATE INDEX ON time_seri
我在超表中存储了很多行。即使在当前的测试配置中,表的大小现在也变得非常大。 对于超过一周的数据,我想通过删除一些较旧的记录,将数据频率从每 5 秒一次减少到每 60 秒一次。 谁能推荐一种这样做的方法
最近才开始使用 TimescaleDB 和 Postgres 来处理大多数数据请求。 但是我遇到了一个问题,我对时间序列数据的请求非常低效。 它是一个可以是任意时间长度的数据系列,具有特定的整数值。
我有一个带有 timescaledb 扩展名的 postgres 数据库。 我的主索引是一个时间戳,我想选择最新的一行。 如果我碰巧知道最新的行发生在某个时间之后,那么我可以使用如下查询: query
总结 我遇到了一个问题,即物化 View 的行限制超过了 Postgres 数据库中允许的最大值。 描述 名为 PAC4200_Metering 的表有 108 个字段,它们都是 double 字段。
这个问题几乎说明了一切。我正在尝试从具有联合主键的表中使用 TimescaleDB 创建超表: CREATE TABLE cars ( id BIGINT NOT NULL GENERATED
我有一个 TimescaleDB 超表,它根据我的时间戳列每 1 个月的时间间隔分成几 block 。 TimescaleDB 是否使用相同的时间戳列来定义何时必须压缩 block ? 如果是这样,处
当块时间间隔太大时,我们如何更改块时间间隔? 用例: 我们有一个现有的 super 表,我们在其中设置了 chunk_time_interval到 1 个月(使用 create_hypertable(
我一直在 TimescaleDB 中保存一些刻度数据,并且对它占用了多少空间感到惊讶。我对此很陌生,但我每天将大约 1000 万行保存到具有以下列的表中: 这已经每天占用大约 35GB,这似乎过多。我
在我的数据库(Postgresql 12;timescaleDB 1.7.0)中有多个指标表,每分钟包含一行和设备。它包含一个 deviceId、时间、四个 double 值和一个枚举值。 有不同的基
我刚刚开始使用 TimescaleDB 并想在带有事件的表上创建一个超表。 最初我想到遵循以下常规模式: CREATE TABLE event ( id serial PRIMARY KEY,
确定我的 TimescaleDB 表的大小 my_table (之前创建了一个超表),我运行了 SQL 查询 pg_size_pretty( pg_total_relation_size('my_ta
我是一名优秀的程序员,十分优秀!