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

相关推荐
qq_5470261791 分钟前
Redis 常见问题
数据库·redis·mybatis
APIshop2 分钟前
Java 实战:调用 item_search_tmall 按关键词搜索天猫商品
java·开发语言·数据库
小陈phd21 分钟前
混合知识库搭建:本地Docker部署Neo4j图数据库与Milvus向量库
数据库·docker·neo4j
2401_8384725129 分钟前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
知识即是力量ol1 小时前
基于 Redis 实现白名单,黑名单机制详解及应用场景
数据库·redis·缓存
zhihuaba1 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
u0109272711 小时前
Python Web爬虫入门:使用Requests和BeautifulSoup
jvm·数据库·python
小光学长1 小时前
基于ssm的农业管理系统8y15w544(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
Mr_Xuhhh1 小时前
MySQL表的增删改查(CRUD)操作详解
数据库·windows
定偶2 小时前
MySQL安装
数据库·mysql