Postgresql HStore 插件试用小结
一, 安装
环境介绍:官方说postgresql 9.3 版本之后支持HStore 插件,目前最新版本10.3
本次测试版本:10.1 或 9.6.2
进入psql 运行环境,使用管理员(高级别用户)进入服务器,连接某个应用数据库。
# \c 命令,数据库名 , 高级别用户 \c databasename postgres; # 启用插件 create extension hstore; # 切换普通用户 \c databasename ir_user; # 察看Hstore 使用情况 \dT hstore;
二, 使用Hstore
新增列(Hstore)
alter table tbl_name add column column_name hstore;
给列赋值
update tbl_name set column_name =('exp=>' || exp || ', wealth=>' || wealth )::hstore;
查询
Select * from tbl_name where column_name ? 'exp’
修改
Select * from tbl_name where column_name || ‘exp=>new_value’::hstore
新增
Select * from tbl_name where column_name || ‘exp2=>value2’::hstore
删除
Select * from tbl_name where column_name - ‘exp2’
三, 性能测试
a) 数据准备,分拣平台2kw条子域名数据,列(20个)
数据表 1 : select * from test.tmp_jackical_hstore2 limit 2;
数据表2 : select * from test.bt_sub_domain limit 2;
测试sql1(hstore) : select * from test.tmp_jackical_hstore2 where domain_hstore2 ? 'zcrbjx.cn.china.cn';
测试sql2 :select * from test.bt_sub_domain where domain_name = 'zcrbjx.cn.china.cn';
两个表都没有加索引 语句1 : 17.561 s
语句2: 5.219 s
b) 追加索引
给 hstore 列加上 gist 索引
CREATE INDEX ***** ON test.tmp_jackical_hstore2 USING gist(domain_hstore2);
给 没有hstore 的表加 btree 索引 :
CREATE INDEX **** ON test.bt_sub_domain USING btree(domain_name );
再次测试 语句1 : 7 s 左右
语句2 : 0.122 s
被正常数据秒杀了。。。
继续优化 ....
c) 再次给Hstore查询条件加索引
给 hstore 列继续 加上 btree 索引 : CREATE INDEX **** ON test.tmp_jackical_hstore2 USING btree(hstore_keys(domain_hstore2));
到目前未知,己给hstore 这列加了,gist 与 btree索引 了,来看看性能吧。
测试语句1: select * from test.tmp_jackical_hstore2 where hstore_keys(domain_hstore2) = 'zcrbjx.cn.china.cn';
测试语句2: select * from test.bt_sub_domain where domain_name = 'zcrbjx.cn.china.cn';
再再次测试 语句1 : 0.122s
语句2 : 0.122s
结论:Hstore 提供key-value 保存形式,但性能不大好,需要加入有针对性查询的索引才能提高性能。
附函数:hstore_keys
CREATE OR REPLACE FUNCTION "test"."hstore_keys"("field" hstore)
RETURNS "pg_catalog"."text" AS $BODY$
select array_to_string(akeys($1),',');
$BODY$
LANGUAGE 'sql' IMMUTABLE COST 100
;
ALTER FUNCTION "test"."hstore_keys"("field" hstore) OWNER TO "ir_user";
官方语法:https://www.postgresql.org/docs/9.6/static/hstore.html
Postgresql HStore 插件试用小结的更多相关文章
- JQuery插件使用小结
JQuery插件使用小结
- uploadify在asp.net中的试用小结
花了差不多一下午的时间,总算把uploadify插件运行起来,在此对自己遇到的问题以及过程做一个小结. 一.使用步骤 1.在官网下载最新的插件包,并将包解压. 2.新建asp.net web项目,将解 ...
- PostgreSQL常用插件收集
hexdump -C 数据表文件 -- 查看表文件中数据. pg_stat_statements pgcompacttable -- 在减少锁的情况下,清理表和索引的老空间. pg_repack--P ...
- postgresql 安装插件
最近由于工作需要,学习了citusdata 插件,在按照官方文档装好postgresql 之后,不能在psql 中正常启用其它插件 如 : "create extension pg_trg ...
- PostgreSQL hstore 列性能提升一例
PostgreSQL 支持hstore 来存放KEY->VALUE这类数据, 事实上也相似于ARRAY或者JSON类型. 要高效的使用这类数据,当然离不开高效的索引.我们今天就来看看两类不同的 ...
- fullpage.js全屏滚动插件使用小结
刚做好公司网站,通过全屏滚动,显著提高了官网的浏览体验.遂总结一下使用fullpage.js的方法.欢迎指正 一. fullpage.js简介 fullpage.js是一套实现浏览器全屏滚动的js插件 ...
- javascript插件编写小结
写JS插件,最好是先通过HTML方式将展示结果显示出来,然后再封装成JS插件,将其画出来.JS模板如下: (function($){ $.fn.fnName = function(options){ ...
- jquery validate 插件使用小结
项目中整合了jquery validate插件,仿照别人的使用写了我的表单验证,结果不起作用.然后就各种找原因. 在网上下了jquery validate插件的完整包,看了看里边的例子,跟我的使用貌似 ...
- 阿里巴巴Java规约插件试用
阿里Java开发规约Eclipse插件介绍 阿里巴巴集团配合<阿里巴巴Java开发手册>PDF终极版开发的IDE插件,目前包括IDEA插件.Eclipse插件. 安装 检查环境 插件要求: ...
随机推荐
- CSMA/CD 3
一.二进制指数类型退避算法 (truncated binary exponential type) 发生碰撞的站在停止发送数据后,要推迟(退避)一个随机时间才能再发送数据. 目的:重传时再次发生碰撞的 ...
- PetaPoco轻量级ORM框架 - 入门安装
PetaPoco 是一个开源轻量级ORM,够小,够快,单文件 在GitHub上有很高的人气 1377星,几年来作者一直在更新 当前版本6.0.317 - Netstandard 2.0(同时支持.ne ...
- ZTree 使用范例
http://www.treejs.cn/v3/api.php zTree v3.x 入门指南 Api 文档 https://github.com/zTree/zTree_v3 下载ZTree v3 ...
- BZOJ2588:Count on a tree(主席树)
Description 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权.其中lastans是上一个询问的答案,初始 ...
- jQuery中异步请求
1.load方法 使用load()方法通过Ajax请求加载服务器中的数据,并把返回的数据放置到指定的元素中,它的调用格式为: $(selector).load(URL,data,callback); ...
- 6、Android---运用手机多媒体(待完成)
6.1.程序运行在手机上 6.2.使用通知 通知是Android中比较由特色的一个功能 当某个应用程序需要向用户发出一些提示信息时 而该程序由不在前台的显示 就可以借助通知来实现 6.2.1.通知的基 ...
- php memcache分布式和要注意的问题
Memcache的分布式介绍 memcached虽然称为“分布式”缓存服务器,但服务器端并没有“分布式”功能.服务器端仅包括内存存储功能,其实现非常简单.至于memcached的分布式,则是完全由客户 ...
- ethersjs运行时出现的问题
1.在运行部署在ganache1.1.0上的合约中的某个函数时,出现了这样的问题,之前部署在geth上时并没有这样的问题 userdeMacBook-Pro:test-ethers user$ nod ...
- selenium通过python字典获取配置
python字典默认的是string item={"browser " : 'webdriver.irefox()', 'url' : 'http://xxx.com'} 如果这样 ...
- POJ 2299 Ultra-QuickSort 求逆序数 (归并或者数状数组)此题为树状数组入门题!!!
Ultra-QuickSort Time Limit: 7000MS Memory Limit: 65536K Total Submissions: 70674 Accepted: 26538 ...