-- 创建一个新的Hypertable,即在TimescaleDB中创建一个时间序列数据库
CREATE EXTENSION IF NOT EXISTS timescaledb CASCADE;
SELECT timescaledb_create_hypertable('weather_data', 'time');
-- 创建一个新的角色,并授予TimescaleDB权限
CREATE ROLE weather_data_role WITH LOGIN PASSWORD 'password';
GRANT ALL PRIVILEGES ON DATABASE weather_data TO weather_data_role;
SELECT timescaledb_promote_user_to_hypertable_role('weather_data_role');
-- 创建一个新的表,用于存储天气数据
CREATE TABLE weather_data (
time TIMESTAMPTZ NOT NULL,
city VARCHAR(80),
temperature DOUBLE PRECISION,
humidity DOUBLE PRECISION,
precip DOUBLE PRECISION,
windspeed DOUBLE PRECISION
);
-- 将weather_data表转换为TimescaleDB的Hypertable
SELECT timescaledb_create_hypertable('weather_data', 'time');
这个示例代码展示了如何在PostgreSQL中使用TimescaleDB来创建一个新的时间序列数据库。首先,我们安装TimescaleDB扩展,并将一个现有的表转换为一个Hypertable。接着,我们创建一个新的角色,并为其提供适当的权限。最后,我们创建一个新的表,用于存储天气数据,并将其转换为一个TimescaleDB的Hypertable。