PostgreSQL
连接数据库
你可以通过端口 4003
使用 PostgreSQL 连接到 GreptimeDB。
只需在命令中添加 -U
参数,后跟你的用户名和密码。以下是一个示例:
psql -h <host> -p 4003 -U <username> -d public
管理表
请参考管理表。
写入数据
请参考写入数据.
读取数据
请参考 读取数据.
时区
GreptimeDB 的 PostgreSQL 协议遵循原始 PostgreSQL 的 时区处理方式。
默认情况下,PostgreSQL 使用服务器的时区来处理时间戳。
你可以使用 SQL 语句 SET TIMEZONE TO '<value>';
为当前会话设置 time_zone
变量来覆盖服务器时区。
time_zone
的值可以是:
- 时区的全称,例如
America/New_York
。 - 时区的缩写,例如
PST
。 - UTC 的偏移量,例如
+08:00
。
你可以使用 SHOW
来查看当前的时区设置。例如:
SHOW VARIABLES time_zone;
TIME_ZONE
-----------
UTC
将会话时区更改为 +1:00
:
SET TIMEZONE TO '+1:00'
有关时区如何影响数据的插入和查询,请参考写入数据和查询数据中的 SQL 文档。
外部数据
利用 Postgres 的 FDW 扩 展, GreptimeDB 可以 被配置为 Postgres 的外部数据服务。 这使得我们可以用 Postgres 服务器上无缝地查询 GreptimeDB 里的时序数据,并且可以利用 join 查询同时关联两边的数据。
举个例子,类似设备信息类的物联网元数据,通常存储在 Postgres 这样的关系型数据库中。 现在我们可以利用这个功能,先在 Postgres 利用关系查询过滤出满足条件的设备 ID,然 后直接关联的 GreptimeDB 承载的外部表上查询设备的时序数据。
配置
首先要确保 GreptimeDB 打开了 Postgres 协议,并且她可以被 Postgres 服务器访问到。
在 Postgres 上开启 fdw 扩展。
CREATE EXTENSION postgres_fdw;
将 GreptimeDB 添加为远程服务器。
CREATE SERVER greptimedb
FOREIGN DATA WRAPPER postgres_fdw
OPTIONS (host 'greptimedb_host', dbname 'public', port '4003');
把 Postgres 用户映射到 GreptimeDB 上。这一步是必须步骤。如果你没有在 GreptimeDB 开源版本上启用认证,这里可以填写任意的认证信息。
CREATE USER MAPPING FOR postgres
SERVER greptimedb
OPTIONS (user 'greptime', password '...');
在 Postgres 创建与 GreptimeDB 映射的外部表。这一步是为了告知 Postgres 相应表的数 据结构。注意需要将 GreptimeDB 的数据类型映射到 Postgres 类型上。
对于这样的 GreptimeDB 表:
CREATE TABLE grpc_latencies (
ts TIMESTAMP TIME INDEX,
host STRING,
method_name STRING,
latency DOUBLE,
PRIMARY KEY (host, method_name)
) with('append_mode'='true');
CREATE TABLE app_logs (
ts TIMESTAMP TIME INDEX,
host STRING,
api_path STRING FULLTEXT,
log_level STRING,
log STRING FULLTEXT,
PRIMARY KEY (host, log_level)
) with('append_mode'='true');
其 Postgres 外部表定义如下:
CREATE FOREIGN TABLE ft_grpc_latencies (
ts TIMESTAMP,
host VARCHAR,
method_name VARCHAR,
latency DOUBLE precision
)
SERVER greptimedb
OPTIONS (table_name 'grpc_latencies');
CREATE FOREIGN TABLE ft_app_logs (
ts TIMESTAMP,
host VARCHAR,
api_path VARCHAR,
log_level VARCHAR,
log VARCHAR
)
SERVER greptimedb
OPTIONS (table_name 'app_logs');
为了帮助用户生成这些语句,我们在 GreptimeDB 里增强了 SHOW CREATE TABLE
来直接
输出可执行的语句。
SHOW CREATE TABLE grpc_latencies FOR postgres_foreign_table;
注意在输出的语句中你需要把服务器名 greptimedb
替换为之前在 CREATE SERVER
语句
里使用的名字。
执行查询
至此你可以通过 Postgres 发起查询。并且可以使用一些同时存在在 GreptimeDB 和
Postgres 上的函数,如 date_trunc
等。
SELECT * FROM ft_app_logs ORDER BY ts DESC LIMIT 100;
SELECT
date_trunc('MINUTE', ts) as t,
host,
avg(latency),
count(latency)
FROM ft_grpc_latencies GROUP BY host, t;