postgre+timescaledb笔记

1.postgre教程链接:参考链接
如果您是PostgreSQL的新手,那么这里有一些资源可以帮助您入门:PostgreSQL手册
如果您不熟悉SQL,可以使用以下资源来帮助您入门:
可汗学院:SQL入门
教程重点:SQL教程
代码学院:学习SQL

2.postgre时序数据库的应用场景及使用:参考链接

3.PostgreSQL+TimescaleDB安装详解(Windows):参考链接
postgre安装好后,主服务密码(这个可以重置):postgres;用户名:postgres;密码:admin(用户名密码是在安装时设置的)。
注意:TimescaleDB在安装时,安装文件别放在C盘,可以放在桌面,然后用管理员运行setup.exe文件,在后续的判断中不停的选择yes来优化postgre配置。
1.创建新的数据库:CREATE database tutorial;
2.登陆该数据库:\c tutorial;
3.使用TimescaleDB来拓展该数据库:CREATE EXTENSION IF NOT EXISTS timescaledb CASCADE;
拓展成功后控制台出现如下提示信息:
For more information on TimescaleDB, please visit the following links:

  1. Getting started: https://docs.timescale.com/getting-started
  2. API reference documentation: https://docs.timescale.com/api
  3. How TimescaleDB is designed: https://docs.timescale.com/introduction/architecture
    Note: TimescaleDB collects anonymous reports to better understand and assist our users.
    For more information and how to disable, please see our docs https://docs.timescaledb.com/using-timescaledb/telemetry.
    这时该数据库的拓展Extensions中会出现timescaledb。

使用TimescaleDB

建表时,最好将非超表字段默认设为null
警告:如果将任何其他列的默认值设置为NULL,则更改表的架构将非常有效。如果默认值设置为非null值,则TimescaleDB将需要为属于该超表的所有行(所有块)填充该值。

创建超表

:1.创建标准表

CREATE TABLE conditions (
  time        TIMESTAMPTZ       NOT NULL,
  location    TEXT              NOT NULL,
  temperature DOUBLE PRECISION  NULL,
  humidity    DOUBLE PRECISION  NULL
);

2.将标准表转换成超表,将时间字段作为分片字段

SELECT create_hypertable('conditions', 'time');

3.操作超表,跟普通数据库操作一样
插入与查询

INSERT INTO conditions(time, location, temperature, humidity)
  VALUES (NOW(), 'office', 70.0, 50.0);
SELECT * FROM conditions ORDER BY time DESC LIMIT 100;

修改超级表

ALTER TABLE conditions
  ADD COLUMN humidity DOUBLE PRECISION NULL;

删除超表

DROP TABLE conditions;
最佳实践

TimescaleDB的用户经常有两个常见问题:
我应该为时间分割配置多长时间?
我应该使用空间分区吗?应该使用多少个空间分区?
时间间隔:超表默认时间间隔是,从v0.11.0开始的7天和v0.11.0之前的1个月。
设置时间间隔原则:所有超表时间间隔总块的大小不超过主内存的25%。比如电脑内存是16G,总共10台设备,每50ms存一条数据,1秒钟存20条数据,一天存的数据条数为:2036002410约等于1千700万条,大小大概约为1G,一天存1G数据,电脑内存为16G,总块大小不超过4G,所以时间间隔设为小于4天。
虽然通常将块做成较小而不是太大是比较安全的,但是将间隔设置得太小会导致很多块,这对应于某些类型的查询的计划等待时间的增加,所以将时间间隔设为3天比较合适。
设置时间间隔:1.通过chunk_time_interval在创建超表时进行设置来显式配置时间间隔
chunk_time_interval:块覆盖时间精确到纳秒,一天是1000
10006060*24
实例:
SELECT create_hypertable(‘conditions’, ‘time’, chunk_time_interval => 86400000000);
SELECT create_hypertable(‘conditions’, ‘time’, chunk_time_interval => interval ‘1 day’):指定块的覆盖时间是1天

2.创建超表之后,可以通过调用更改用于新块的间隔set_chunk_time_interval
例子:
SELECT set_chunk_time_interval(‘conditions’, interval ‘24 hours’);
SELECT set_chunk_time_interval(‘conditions’, 86400000000);

模式管理

创建索引
CREATE INDEX ON conditions (location, time DESC);

**创建索引的好处:**创建索引之后,能有效地提高查询数据效率。
**创建索引和使用查询语句的原则:**查询语句的筛选条件顺序根据创建索引的规则来排序。
按时间分区建超表时,timescaledb会自动在表数据上创建时间索引。
建议:一个表建一个复合索引,然后查询语句按照创建的索引字段顺序来查询语句

创建触发器

TimescaleDB支持触发器的全域(也即是触发器触发的时刻)BEFORE INSERT,AFTER INSERT,BEFORE UPDATE,AFTER UPDATE,BEFORE DELETE,AFTER DELETE
创建触发器:创建一个触发器,只要在超表中插入新行,该触发器便会调用此函数

CREATE TRIGGER record_error
  BEFORE INSERT ON conditions
  FOR EACH ROW
  EXECUTE PROCEDURE record_error();

创建触发器函数:
好处,减少程序执行的代码,让数据库来执行。更加好的来分配任务。

添加约束

1.约束某个字段值得范围
2.某个字段外键约束
3.将两个字段设为主键

CREATE TABLE conditions (
    time       TIMESTAMPTZ
    temp       FLOAT NOT NULL,
    device_id  INTEGER CHECK (device_id > 0),
    location   INTEGER REFERENCES locations (id),
    PRIMARY KEY(time, device_id)
    ///UNIQUE(time, device_id, location)
);
SELECT create_hypertable('conditions', 'time');

创建Json类型表字段

CREATE TABLE metrics (
  time TIMESTAMPTZ,
  user_id INT,
  device_id INT,
  data JSONB
);

创建Json类型表字段慎用,最好别用。
数据库JSON字段设计思路:https://www.cnblogs.com/xiashiwendao/p/6985093.html

插入数据

在插入语句时使用ON CONFLICT不执行任何操作:

INSERT INTO conditions
  VALUES ('2017-07-28 11:42:42.846621+00', 'office', 70.1, 50.0)
  ON CONFLICT DO NOTHING;

在插入语句时更新现有数据:

INSERT INTO conditions
  VALUES ('2017-07-28 11:42:42.846621+00', 'office', 70.2, 50.1)
  ON CONFLICT (time, location) DO UPDATE
    SET temperature = excluded.temperature,
        humidity = excluded.humidity;

使用ON CONFLICT的好处,当批量插入数据时,使用ON CONFLICT,整个事务不会失败,仅仅只是跳过有冲突的行。

INSERT INTO conditions
  VALUES
    (NOW(), 'office', 70.0, 50.0),
    (NOW(), 'basement', 66.5, 60.0),
    (NOW(), 'garage', 77.0, 65.2);

提醒:在后面着重的去看看读取数据,可视化数据,提取数据,超表管理,分析工具,实用程序/统计。

这一步废弃:Timescale Cloud登陆邮箱:[email protected] 密码:ww920201
Timescale Cloud注册后无法登陆

下载grafana安装程序

下载地址:https://grafana.com/grafana/download?platform=windows
Grafana介绍 Grafana是一个跨平台的开源的度量分析和可视化工具,可以通过将采集的数据查询然后可视化的展示,并及时通知。
Grafana文档:https://grafana.com/docs/grafana/latest/
安装grafana后,打开Web浏览器,然后转http://localhost:3000 /,利用用户名:admin密码admin,登陆后修改密码为:grafana

配置grafana

登陆成功后添加数据源postgre+timescaledb笔记_第1张图片
选择postgre,然后配置参数,点击保存并测试
postgre+timescaledb笔记_第2张图片
postgre+timescaledb笔记_第3张图片
postgre+timescaledb笔记_第4张图片
postgre+timescaledb笔记_第5张图片

下载安装psql

psql是用于与PostgreSQL或TimescaleDB实例进行交互的标准命令行界面。安装postgre时自动安装了sqlshell,也就是psql

常见的psql命令
这是一张常用命令表,您会发现自己经常使用以下命令:
命令 动作
\l 列出可用的数据库
\c dbname 连接到新数据库
\dt 列出可用表
\d tablename 描述给定表的细节
\dn 列出当前数据库中的所有架构
\df 列出当前数据库中的函数
\h 获取有关SQL命令语法的帮助
? 列出所有psql斜杠命令
\set 系统变量列表
\timing 显示查询执行所需的时间
\x 显示扩展的查询结果
\q 退出 psql
postgre+timescaledb笔记_第6张图片

你可能感兴趣的:(postgre)