postgres linux 环境psql 中文乱码处理

PostgreSQL 中文乱码问题解决方案

PostgreSQL 在 psql 命令行中出现中文乱码通常是由于字符编码设置不正确导致的。以下是几种解决方法:

1. 检查当前数据库编码

复制代码

sqlCopy Code

SELECT pg_encoding_to_char(encoding) FROM pg_database WHERE datname = current_database();

2. 设置客户端编码

在 psql 中执行:

复制代码

sqlCopy Code

\encoding UTF8

3. 永久解决方案

方法一:修改环境变量

在用户配置文件(~/.bashrc 或 ~/.bash_profile)中添加:

复制代码
export PGCLIENTENCODING=UTF8 export LANG=zh_CN.UTF-8 xport LC_ALL=zh_CN.UTF-8 

方法二:修改 PostgreSQL 配置

  1. 编辑 postgresql.conf 文件(通常位于 /etc/postgresql/版本/main/)
  2. 确保以下设置:
复制代码

client_encoding = utf8

lc_messages = 'zh_CN.UTF-8'

lc_monetary = 'zh_CN.UTF-8'

lc_numeric = 'zh_CN.UTF-8'

lc_time = 'zh_CN.UTF-8'

方法三:创建数据库时指定编码

复制代码

sqlCopy Code

CREATE DATABASE dbname WITH ENCODING 'UTF8' LC_COLLATE 'zh_CN.UTF-8' LC_CTYPE 'zh_CN.UTF-8';

4. 检查终端编码

确保终端本身支持 UTF-8 编码,可以通过以下命令检查:

复制代码

bashCopy Code

echo $LANG

如果显示不是 UTF-8 相关编码,需要修改终端设置。

5. 连接时指定编码

连接数据库时使用:

复制代码

bashCopy Code

psql -U username -d dbname --set=client_encoding=UTF8

相关推荐
pixcarp19 小时前
知识库系统的内容资产闭环怎么设计
服务器·数据库·后端·golang
JosieBook19 小时前
【数据库】时序预测能力的分级进化:TimechoAI如何让每一类用户都能精准预见未来
java·开发语言·数据库
吴声子夜歌21 小时前
SQL经典实例——使用多张表
数据库·sql
倔强的石头_1 天前
《Kingbase护城河》——深度解密数据库行锁冲突与等待事件架构
数据库
IT策士1 天前
Redis 从入门到精通:性能调优与多语言客户端对比
数据库·redis·缓存
Bert.Cai1 天前
Oracle INSTR函数详解
数据库·oracle
茉莉玫瑰花茶1 天前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai
ywl4708120871 天前
jwt生产token,简单版helloworld
java·数据库·spring
器灵科技1 天前
AI视频工具实测:Seedance/可灵/HappyHorse谁最能打?
java·运维·数据库·人工智能·github
huangdong_1 天前
京东商品图片视频批量下载与m3u8视频合并技术完整实现方案
大数据·前端·数据库