postgresql9.5 物化视图测试

前端之家收集整理的这篇文章主要介绍了postgresql9.5 物化视图测试前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

copyrighthttp://cupegraf.com/


视图是指数据库只存储定义该视图的查询语句(内容查询时产生),而物化视图是一个其查询语句查询后的内容并存储的视图(内容是创建物化视图刷新视图时产生,数据可修改。独立)。因为物化视图是视图的一个物化表结构,但是里面的数据是创建时刷新查询到额数据,当原数据更新修改时如果物化视图的表没有更新会造成数据的不一致。从9.4开始增加增量刷新,9.5的版本中支持物化视图也支持索引,修改表空间,指定用户访问权限


postgresql9.5物化视图测试:



search package: sudo apt-cache search dtrace-*

dtrac && readline install :sudo apt-get installsystemtap-sdt-dev libssl-devlibpam-dev libxml2-dev libxslt-devlibtcl8.4 libperl-dev python-dev

./configure --prefix=/home/pg5/pgsql9.5-devel --with-port=5433 --with-perl --without-tcl --with-python --with-openssl --with-pam --without-ldap --with-libxml --with-libxslt --enable-thread-safety --with-blocksize=32 --enable-dtrace --enable-debug


make

sudo make install

cd postgresql源码目录/contrib

make

sudo make install(后面要用到fdw)

.bashrc的环境变量要配置:

exportPGHOME=/home/pg5/pgsql9.5-devel
exportPATH=$PATH:$PGHOME/bin
exportPGDATA=/home/pg5/data
exportPGUSER=pg5
exportPGPORT=5433


测试数据:

createdatabaseeachmaENCODING=UTF8;
createtabletbl(idintprimarykey,infotext,crt_timetimestamp);
insertintotblselectgenerate_series(1,100000),md5(random()::text),clock_timestamp();
creatematerializedviewtbl_viewasselect*fromtblwhereid<1000withnodata;
creatematerializedviewtbl_view1asselect*fromtblwithnodata;
createuniqueindexidx_tbl_view_idontbl_view(id);
createuniqueindexidx_tbl_view1_idontbl_view1(id);
refreshmaterializedviewtbl_view;
refreshmaterializedviewtbl_view1;
\timing#打开事务执行时间


增量刷新;refresh materialized view concurrently tbl_view1;

非增量刷新:refresh materialized view tbl_view1;

pg中查看物化视图表:

select * from pg_matviews;

eachma=#select*frompg_matviews;
-[RECORD1]+-------------------------
schemaname|public
matviewname|tbl_view
matviewowner|pg5
tablespace|
hasindexes|t
ispopulated|t
definition|SELECTtbl.id,+
|tbl.info,+
|tbl.crt_time+
|FROMtbl+
|WHERE(tbl.id<1000);
-[RECORD2]+-------------------------
schemaname|public
matviewname|tbl_view1
matviewowner|pg5
tablespace|
hasindexes|t
ispopulated|t
definition|SELECTtbl.id,+
|tbl.crt_time+
|FROMtbl;

Time:0.758ms


增量刷新不会锁表,阻断其他查询。但是视图的非增量刷新会锁表。两者利弊不一,前者不锁表,但是执行需要的时间比较长,因为是Join查询需要一条条的数据进行对比,以时间来换取查询锁。以至于不会影响到物化视图的查询工作。而后者的执行等待时间比较短.但其他的查询需要等待刷新之后才能完成:

增量刷新:

eachma=#begin;
BEGIN
Time:0.117ms
eachma=#refreshmaterializedviewconcurrentlytbl_view1;
REFRESHMATERIALIZEDVIEW
Time:2085.527ms
eachma=#commit;
COMMIT
Time:2.718ms
eachma=#end
#非增量刷新
eachma=#begin;
BEGIN
Time:0.104ms
eachma=#refreshmaterializedviewtbl_view1;
REFRESHMATERIALIZEDVIEW
Time:209.312ms
eachma=#commit;
COMMIT
Time:9.777ms
eachma=#end;
WARNING:thereisnotransactioninprogress
COMMIT
Time:0.318ms

pg是支持外部表物化视图。例如oracle里面有一个表的数据是我们想需要的,但是一般情况下是需要我们通过odbc或者是dump出来。但是因为pg支持外部表(FDW,dblink)。可以通过创建一个我们需要oracle中数据,那么可以先创建一个外部表,然后给这个外部表创建物化视图,这样也减少的数据的拷贝,oracle有数据更新时也可以去更新视图。但要注意物化视图的表增量的刷新要与远程表规则一致(索引)

下面是做一个外部表(以postgresql9.4的库为外部库)的物化视图测试:

eachma=# CREATE EXTENSION postgres_fdw;

安装成功:

eachma=#\df
Listoffunctions
Schema|Name|Resultdatatype|Argumentdatatypes|Type
--------+------------------------+------------------+---------------------+--------
public|postgres_fdw_handler|fdw_handler||normal
public|postgres_fdw_validator|void|text[],oid|normal
createserverpg4VERSION'9.4'foreigndatawrapperpostgres_fdwOPTIONS(host'211.69.228.50',dbname'tech',port'5432');#创建server

CREATEUSERMAPPINGforpg5serverpg4options(user'eachma',password'612345');#创建映射用户

CREATEFOREIGNTABLEorders(order_numintegernotnull,order_datedatenotnull,cust_idcharacter(10)notnull)serverpg4OPTIONS(schema_name'public',table_name'orders');#外部表目前不支持主健约束

eachma=#select*frompg_foreign_table;#外部表
-[RECORD1]-------------------------------------
ftrelid|16579
ftserver|16577
ftoptions|{schema_name=public,table_name=orders}
eachma=#select*fromorders;
order_num|order_date|cust_id
-----------+------------+------------
20005|2012-05-01|1000000001
20006|2012-01-12|1000000003
20007|2012-01-30|1000000004
20008|2012-02-03|1000000005
20009|2012-02-08|1000000001
(5rows)

eachma=#\dt
Listofrelations
Schema|Name|Type|Owner
--------+------+-------+-------
public|tbl|table|pg5
(1row)

创建一个外部表物化视图:

eachma=#creatematerializedvieworder_viewasselect*fromorderswithnodata;
SELECT0
eachma=#select*fromorder_view;#没有刷新
ERROR:materializedview"order_view"hasnotbeenpopulated
HINT:UsetheREFRESHMATERIALIZEDVIEWcommand.
eachma=#refreshmaterializedvieworder_view;
REFRESHMATERIALIZEDVIEW
eachma=#select*fromorder_view;
order_num|order_date|cust_id
-----------+------------+------------
20005|2012-05-01|1000000001
20006|2012-01-12|1000000003
20007|2012-01-30|1000000004
20008|2012-02-03|1000000005
20009|2012-02-08|1000000001
(5rows)
eachma=#select*frompg_matviews;
-[RECORD1]+--------------------------
schemaname|public
matviewname|order_view
matviewowner|pg5
tablespace|
hasindexes|f
ispopulated|t
definition|SELECTorders.order_num,+
|orders.order_date,+
|orders.cust_id+
|FROMorders;

参考:http://www.postgresql.org/docs/9.5/static/postgres-fdw.html

postgresql资料:https://github.com/ty4z2008/Qix/blob/master/pg.md

猜你在找的Postgre SQL相关文章