文档章节

PostgreSQL 简体中文区域设置性能改进实践

有理想的猪
 有理想的猪
发布于 2013/07/08 15:44
字数 328
阅读 401
收藏 8

相关阅读《PostgreSQL 字符集下区域设置对性能的影响改进办法》
http://my.oschina.net/quanzl/blog/135721

按照这个思路,将中文排序信息内置于数据库内核之中,如果 locale 选择中文,由此检索排序位置,而不是通过系统API strcoll()。

encoding均为utf-8,数据量为54996,中文与ascii换杂,同一硬件平台,openSUSE。
以下为以 pgAdminIII 为客户端创建索引的测试结果:

locale=C,原生PG:查询成功但无结果,耗时: 140 毫秒(ms)。
locale=zh_CN.utf8,原生PG:查询成功但无结果,耗时: 985 毫秒(ms)。
locale=zh_CN.utf8,修改后:查询成功但无结果,耗时: 203 毫秒(ms)。

以上结果都是记录“创建、删除、再创建”过程的第二次创建时间。

同时发现一个问题,Linux下平台的中文排序比较怪:
select * from (values('阿'),('啊'),('腌'),('包'),('')) as a(e) order by e;
返回结果
""
"腌"
"阿"
"啊"
"包"
猜测这里的“腌”,取“a za”发音。不是 yan 音。

不管怎样,后边尝试跟社区沟通一下,看他们能不能接受。以前就PG在不同系统下排序混乱的话题讨论,有位大仙说这样(使用操作系统排序)挺好。

© 著作权归作者所有

有理想的猪
粉丝 136
博文 115
码字总数 47557
作品 0
红挢
高级程序员
私信 提问
加载中

评论(1)

有理想的猪
有理想的猪 博主
vmware虚拟机Windows测试结果如下:
修改前:查询成功但无结果,耗时: 343 毫秒(ms)。
修改后:查询成功但无结果,耗时: 235 毫秒(ms)。
提升不如Linux明显,看起来Windows自身的strcoll()也比Linux快很多。
PostgreSQL安装详细步骤(windows)

PostgreSQL安装: 一、windows下安装过程 安装介质:postgresql-9.1.3-1-windows.exe(46M),安装过程非常简单,过程如下: 1、开始安装: 2、选择程序安装目录: 注:安装 PostgreSQL 的分...

引鸩怼孑
2015/04/21
360
1
PostgreSQL 相似文本检索与去重 - (银屑病怎么治?银屑病怎么治疗?银屑病怎么治疗好?银屑病怎么能治疗好?)

标签 PostgreSQL , 相似字符串 , 全文检索 , 去重 , 相似问题 , 医疗 , plr , plpython , madlib , 文本处理 背景 在云栖社区的问答区,有一位网友提到有一个问题: 解这个问题的思路 1. 首先...

德哥
2018/04/18
0
0
PostgreSQL 中文帮助信息 乱码

在 Win7 32 位环境下安装 PostgreSQL 9.4.1 ,安装完成后出现 中文帮助信息乱码 问题,查了些资料也没找到解决办法,请高手指导啊。 安装时,【Select the locale to be used by the new dat...

asusvw121
2015/09/08
1K
1
[笔记]将系统的数据库从MySQL 5.5迁移到PostgreSQL 9.1

环境 Windows Server 2003 x64 简体中文, MySQL 5.5 (UTF8编码), PostgreSQL 9.1.4-1 (UTF8编码) Spring 3.0.7, Struts 2.3.4, Hibernate 3.5.5 从MySQL迁移到PostgreSQL ------------------......

leeoo
2012/07/22
1K
3
Postgresql中国用户会 2013年广州社区活动

活动介绍 哈尼雅咖啡厅-Postgresql中国用户会 2013年广州社区活动 报名地址:http://gzpostgresql.51qiangzuo.com/ 内容:1.基于Postgresql的RHEV容灾方案 2.postgres查询计划分析 3.postgr...

Lu-e
2013/04/09
717
3

没有更多内容

加载失败,请刷新页面

加载更多

高防CDN的出现是为了解决网站的哪些问题?

高防CDN是为了更好的服务网络而出现的,是通过高防DNS来实现的。高防CDN是通过智能化的系统判断来路,再反馈给用户,可以减轻用户使用过程的复杂程度。通过智能DNS解析,能让网站访问者连接到...

云漫网络Ruan
今天
13
0
聊聊Tomcat中的连接器(Connector)

上期回顾 上一篇文章《Tomcat在SpringBoot中是如何启动的》从main方法启动说起,窥探了SpringBoot是如何启动Tomcat的,在分析Tomcat中我们重点提到了,Tomcat主要包括2个组件,连接器(Conne...

木木匠
今天
9
0
OSChina 周一乱弹 —— 熟悉的味道,难道这就是恋爱的感觉

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @xiaoshiyue :好久没分享歌了分享张碧晨的单曲《今后我与自己流浪》 《今后我与自己流浪》- 张碧晨 手机党少年们想听歌,请使劲儿戳(这里)...

小小编辑
今天
2.4K
22
SpringBoot中 集成 redisTemplate 对 Redis 的操作(二)

SpringBoot中 集成 redisTemplate 对 Redis 的操作(二) List 类型的操作 1、 向列表左侧添加数据 Long leftPush = redisTemplate.opsForList().leftPush("name", name); 2、 向列表右......

TcWong
今天
43
0
排序––快速排序(二)

根据排序––快速排序(一)的描述,现准备写一个快速排序的主体框架: 1、首先需要设置一个枢轴元素即setPivot(int i); 2、然后需要与枢轴元素进行比较即int comparePivot(int j); 3、最后...

FAT_mt
昨天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部