pg readme

Postgres DB demo

  • Table of content:

Reference:

Guidelines

============ env ============
PG_HOME=/global/ocean/data/ocean/postgre
PG_BIN=$PG_HOME/current/bin
PGLOG=$PG_HOME/data/logs/pg96
PGLOG_FILE=$PGLOG/postgre_server.log
PGDATA=$PG_HOME/data/pg96

============ control ============
${PG_BIN}/initdb -U $PGUSER -W    #run once 

${PG_BIN}/pg_ctl -l $PGLOG_FILE start   
#${PG_BIN}/pg_ctl -l $PGLOG_FILE  -o "-F -p 5480" start 
${PG_BIN}/pg_ctl -l $PGLOG_FILE restart 
${PG_BIN}/pg_ctl   status
${PG_BIN}/pg_ctl -l $PGLOG_FILE  stop -m fast

============ create  ============
${PG_BIN}/createdb -O $PGUSER  $PGDATABASE
${PG_BIN}/createuser -P -E -e $PGUSER

${PG_BIN}/dropuser $PGUSER
${PG_BIN}/dropdb  $PGDATABASE

============ login psql ============
psql -U username -h hostname -p port -d dbname

PGUSER=admin
PGPASSWORD=password
PGDATABASE=meta_int

============ ops in psql =============
help: \h
quit: \q

list DB: \l
list tables: \dt *.* (all table of all schema)
list index: \di
lsit schema: \dn

switch DB: \c dbname:
desc table: \d tblname

alter table [tblname] add column [col_name] [type];

install DB

// find rpm
ls -lt /net/stealth.nj.ssmb.com/export1/home1.localhost/sw/Linux | grep -i postgre 
// install
rpm -ivh postgresql96-libs-9.6.15-1PGDG.rhel6.x86_64.rpm
rpm -ivh postgresql96-9.6.15-1PGDG.rhel6.x86_64
rpm -ivh postgresql96-server-9.6.15-1PGDG.rhel6.x86_64

ln -s /usr/pgsql-9.6/bin $PG_HOME/current

// config file:
$PGDATA\pg_hba.conf
$PGDATA\postgresql.conf

// uninstall
rpm -e postgresql96-server-9.6.15-1PGDG.rhel6.x86_64

PG features

connect local

  • connect by vscode sqltools:

[图片上传失败...(image-fc2ec7-1572518730678)]

jdbc_url:jdbc:postgresql://oceanap02d.nam.nsroot.net:5432/meta_int
url: postgresql://oceanap02d.nam.nsroot.net:5432/meta_int

username: admin
password: password

Json support

there are 2 types to save json data:

Json type: will save as document 
Jsonb type: has only useful value for higher performance (GIN index)

  • Jsonb/Json query ops

[图片上传失败...(image-7e61ea-1572518730678)]


  • Jsonb specially supported query

[图片上传失败...(image-ba7b0e-1572518730678)]

  • example
-- @block return json object
select '{"foo": [true, "bar"], "tags": {"a": 1, "b": null}}'::json->'tags' as tags;

-- @block return text
select '{"foo": [true, "bar"], "tags": {"a": 1, "b": null}}'::json->>'tags' as tags;

-- @block path select: will return "bar"
select '{"a": [1, "bar", 2], "tags": {"a": 1, "b": null}}'::json#>'{a,1}';

-- @block contain value
select '{"nickname": "gs", "avatar": "avatar_url", "tags": ["python", "golang", "db"]}'::jsonb @> '{"nickname": "gs"}'::jsonb;
--select '{"nickname": "gs", "avatar": "avatar_url", "tags": ["python", "golang", "db"]}'::jsonb->'nickname' = '"gs"';

-- @block select content of accounts_jsonb
-- @conn PGSQL
select content from test.accounts_jsonb

-- @block contain nickname = 'cowww'
-- @conn PGSQL
select content from test.accounts_jsonb where content @> '{"nickname" : "cowww"}'

-- @block select content tags contain 'scala'
-- @conn PGSQL
select content from test.accounts_jsonb where content::jsonb->'tags' ? 'scala'

-- @block map normal row to json object
select row_to_json(company) from public.company;

  • more details refer to: here

Server push

可以将关于特定主题的消息广播给正在监听该主题的所有连接订户。
消息由Postgres服务器推送到侦听客户端。不需要轮询,
但您的数据库驱动程序应支持异步向应用程序传递通知。

  • SQL
-- create a listener on a channel
LISTEN 'my_channel';

-- send message to channel
NOTIFY 'my_channel', 'my message text';


-- 结合 trigger 触发器 pg_notify:

SELECT pg_notify('foo_events', '{"userid":42,"action":"grok"}');

  • Java client

connection.notificationHandler(notification -> {
  System.out.println("Received " + notification.getPayload() + 
  " on channel " + notification.getChannel());
});

connection.query("LISTEN some-channel", ar -> {
  System.out.println("Subscribed to channel");
});

Table inherit

  • example
CREATE TABLE invoices (
    invoice_number   int  NOT NULL PRIMARY KEY,
    issued_on        date NOT NULL DEFAULT now()
);

CREATE TABLE government_invoices (
    department_id    text NOT NULL
) INHERITS (invoices);

PARTITION 拆分表: postgreSQL 10

将一个逻辑的大表,分割成物理的小表。从而获得几点优势:

1.提高查询性能,特别是对于某些只落在某一段区间的查询;分块可以减少索引的大小,从而可以全部放在内存中

2.当查询访问某一块的大部分数据时,原来需要随机访问的,现在可以seq scan;避免随机扫描

3.块操作(加载或者删除)都可以直接对partition操作
ALTER TABLE DETACH PARTITION或者直接 DROP TABLE)进行处理,避免了vacuum的负载

4.冷热数据分离存储

CREATE TABLE measurement (
    city_id         int not null,
    logdate         date not null,
    peaktemp        int,
    unitsales       int
) PARTITION BY RANGE (logdate);

CREATE TABLE measurement_y2008m01 PARTITION OF measurement
    FOR VALUES FROM ('2008-01-01') TO ('2008-02-01')
    WITH (parallel_workers = 4)
    TABLESPACE fasttablespace;

CREATE TABLE measurement_y2006m02 PARTITION OF measurement
    FOR VALUES FROM ('2006-02-01') TO ('2006-03-01');

CREATE TABLE measurement_y2006m03 PARTITION OF measurement
    FOR VALUES FROM ('2006-03-01') TO ('2006-04-01');

postgres_fdw 外包装数据

Hash,GIN, BRIN index


Array type 数组类型, range 区间类型

https://www.kancloud.cn/hfpp2012/postgresqlbook/467209

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 230,321评论 6 543
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 99,559评论 3 429
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 178,442评论 0 383
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 63,835评论 1 317
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 72,581评论 6 412
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 55,922评论 1 328
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 43,931评论 3 447
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 43,096评论 0 290
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 49,639评论 1 336
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 41,374评论 3 358
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 43,591评论 1 374
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 39,104评论 5 364
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 44,789评论 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 35,196评论 0 28
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 36,524评论 1 295
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 52,322评论 3 400
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 48,554评论 2 379

推荐阅读更多精彩内容