如何使 Postgresql 的psql 使用 中文提示信息

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介:

2000元阿里云代金券免费领取,2核4G云服务器仅664元/3年,新老用户都有优惠,立即抢购>>>


阿里云采购季(云主机223元/3年)活动入口:请点击进入>>>,


阿里云学生服务器(9.5元/月)购买入口:请点击进入>>>,

和很多的开源软件一样,Postgresql 中使用  GNU 的 gettext 机制来完成多语言变换。

 它在自己的src各子目录下准备了很多的po文件,比如 src/bin/psql 目录下的:

zh_CN.po , jp.po, fr.po 等。

 按理说,configure 时,加入 –enable-nls=zh_CN 就可以了。但是执行了很多次都没有成功。

由于一个偶然的因素,才发现了其中的奥秘,现在把正确的作法说明如下:

 -------------正确作法开始------------------

步骤一

./configure
gmake
gmake install

 

步骤二

删除postgresql安装文件所在目录(就是包含configure文件的那个),

重新解压 tar文件,然后再执行 

 

./configure --enable-nls=zh_CN
gmake
gmake install

-------------正确作法完了------------------

 

再把错误方法说明一下:

-------------错误作法开始------------------

./configure --enable-nls=zh_CN

gmake

gmake install

-------------错误作法完了------------------

直接用 ./configure –enable-nls=zh_CN的时候,在执行 gmake时候,会碰到如下错误

"undefined reference to  libpq_gettext"

 

其原因是这样的:PostgreSQL中调用 gettext的时候,设计了一个函数libpq_gettext。

而这个函数却是定义在 fe-misc.c 文件中的。

在./configure —enable-nls 的情况下,

对libpq_gettext 的调用,将转化为寻找外部函数 libpq_gettext的过程。

由于PostgreSQL开发者的疏忽,此时 定义 libpq_gettext函数的 fe-misc尚未被编译,libpq_gettext尚未存在,所以gmake会出错。

 

反过来,./configure 没有加 –enable-nls参数的情况下,

根据宏定义,对libpq_gettext(x)调用,直接转换为参数x本身。尚未涉及fe-misc, 所以gmake会成功。

具体来说,请参看如下的函数定义信息。

可以这样地推断:

PostgreSQL的开发者,也是先进行了一般的编译/链接,然后并没有删除目标文件就开始调试加参数的configure/gmake/gmake install。

所以他们没有发现这个纰漏。因此,当我们加各种参数来编译PostgreSQL无法通过的时候,可以参考本文的方法。

 

最后,看一下psql下使用中文信息的效果:

 [postgresql@localhost ~]$ /usr/local/pgsql/bin/psql

psql(9.0.2)
输入 "help" 来获取帮助信息.

postgres=# \password
输入新的密码:
再次输入:
postgres=#\q

而如果不加 ./configure --enable-nls ,则信息为:

Enter new password:

Enter password again:

----------------------------------------------------函数定义信息开始---------------------------------------------

复制代码
Libpq_int.h中的宏如下定义:

#ifdef ENABLE_NLS
    libpq_gettext(const char *msgid)
   __attribute__(format_arg(1));
#else
    #define libpq_gettext(x)  (x)
#endif  

fe_misc.c中对 libpq_gettext是有明确的定义的:

#ifdef ENABLE_NLS
char *libpq_gettext(const char *msgid)
{
    static bool already_bound = false;
     if (!already_bound)
     {
        /** dgettext() preserves errno, but bindtextdomain() doesn't */
        #ifdef WIN32
        int  save_errno = GetLastError();
        #else
        int  save_errno = errno;
        #endif

        const char *ldir;
        already_bound = true;
        /** No relocatable lookup here because the binary could be anywhere */
        ldir = getenv("PGLOCALEDIR");

        if (!ldir)
            ldir = LOCALEDIR;

        bindtextdomain(PG_TEXTDOMAIN("libpq"), ldir);

        #ifdef WIN32
        SetLastError(save_errno);
        #else
        errno = save_errno;
        #endif
    }
    return dgettext(PG_TEXTDOMAIN("libpq"), msgid);
}
复制代码








本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/07/10/2584808.html,如需转载请自行联系原作者

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
4天前
|
关系型数据库 分布式数据库 数据库
PolarDB for PostgreSQL报错问题之psql连接数据库报错如何解决
PolarDB for PostgreSQL是基于PostgreSQL开发的一款云原生关系型数据库服务,它提供了高性能、高可用性和弹性扩展的特性;本合集将围绕PolarDB(pg)的部署、管理和优化提供指导,以及常见问题的排查和解决办法。
|
4天前
|
关系型数据库 Linux 数据安全/隐私保护
PostgreSQL【部署 02】在线安装PostgreSQL(Some psql features might not work 问题处理+角色密码设置+配置远程访问)
PostgreSQL【部署 02】在线安装PostgreSQL(Some psql features might not work 问题处理+角色密码设置+配置远程访问)
42 0
PostgreSQL【部署 02】在线安装PostgreSQL(Some psql features might not work 问题处理+角色密码设置+配置远程访问)
|
4天前
|
SQL 关系型数据库 PostgreSQL
PostgreSQL【SQL 01】根据条件更新字段值或追加信息STRPOS(string, substring)函数使用及LIKE函数对比
PostgreSQL【SQL 01】根据条件更新字段值或追加信息STRPOS(string, substring)函数使用及LIKE函数对比
67 0
|
8月前
|
前端开发 关系型数据库 数据库
使用psql操作PostgreSQL数据库
使用psql操作PostgreSQL数据库
72 0
|
10月前
|
SQL 关系型数据库 Java
PostgreSQL统计信息的几个重要视图
PostgreSQL统计信息的几个重要视图
124 0
|
12月前
|
SQL 存储 Oracle
【postgreSQL】psql工具特有的快捷命令2
【postgreSQL】psql工具特有的快捷命令2
122 0
|
12月前
|
关系型数据库 PostgreSQL
使用psql连接 postgresql失败
使用psql链接postgresql服务失败,telnet这个地址和端口有没有反映。
113 0
|
12月前
|
SQL Oracle 关系型数据库
【postgreSQL】psql工具特有的快捷命令
【postgreSQL】psql工具特有的快捷命令
8841 1
|
存储 Cloud Native 关系型数据库
鼎医信息完成阿里云PolarDB数据库产品生态集成认证
近日,上海鼎医信息技术有限公司(以下简称鼎医信息)与阿里云PolarDB 开源数据库社区展开产品集成认证。测试结果表明,鼎医信息旗下医院资源运营管理软件(V5.0)与阿里云以下产品:阿里云PolarDB数据库管理软件,完全满足产品兼容认证要求,兼容性良好,系统运行稳定。
鼎医信息完成阿里云PolarDB数据库产品生态集成认证
|
SQL 缓存 监控
PostgreSQL 监控1统计进程和统计信息的解读|学习笔记(二)
快速学习PostgreSQL 监控1统计进程和统计信息的解读
332 0
PostgreSQL 监控1统计进程和统计信息的解读|学习笔记(二)
http://www.vxiaotou.com