Postgresql客户端psql提示符(Prompt)配置

为防止连错库,导致误操作,可以配置Prompt提示符。

在 psql中,可以通过环境变量PROMPT1(以及PROMPT2、PROMPT3)定义命令行提示符的显示内容。

这些占位符(如%M、%n 、%/等)会在运行时被替换为实际信息,用来让DBA或开发者在终端里快速看到当前连接的数据库信息、用户、主机、事务状态。

用途主要有:

1. **显示连接信息:**区分你现在连的是哪台数据库主机、哪个数据库、什么用户。

2. **安全提示:**不同提示符(如>Vs #)提醒你是普通用户还是超级用户,避免误操作。

3. **事务状态提示:**显示是否在事务中,或者事务是否失败,避免忘记提交/回滚。

4 **、交互式操作更直观:**特别是同时管理多台数据库时,提示符能防止混淆。

|---------|--------------------------------------------|
| 符号 | 含义 |
| %M / %m | 主机名(完整/截断) |
| %n | 当前会话用户名 |
| %/ | 当前数据库名 |
| %# | >普通用户提示符,# 数据库超级用户提示符 |
| %R | 输入提示符:检测未闭合的引号/漏掉分号 |
| %x | 1. 事务(TX)状态: 2. 空值→无事务 3. *在事务中 4. !→事务失败 |

举个例子:

如果设置:

\set PROMPT1 '%n@%M:%/ %# '

登录psql后可能会显示:

postgres@dbserver:mydb #

这里表示:当前用户postgres ,主机 dbserver,数据库 mydb ,并且是超级用户。

相关推荐
aka10 小时前
PostgreSQL高效建表存储数据对齐问题
postgresql
幺洞两肆11 小时前
以StarRocks为例讲解MPP架构和列式存储
大数据·数据库
R瑾安11 小时前
mysql集群部署(Mysql Group Replication)
数据库·mysql·wpf
周小码11 小时前
pgroll:简化PostgreSQL零停机迁移
数据库·postgresql
代码的余温11 小时前
解析SQL Server核心服务与功能
数据库·sqlserver
没刮胡子11 小时前
mysql分页SQL
数据库·sql·mysql
fatsheep洋11 小时前
sql项目总结
数据库·sql
高级测试工程师欧阳11 小时前
SQLint3 模块如何使用
数据库·python·mysql·oracle
ActionTech11 小时前
2025 年 8 月《大模型 SQL 能力排行榜》发布
数据库·sql·oracle
一心09211 小时前
SQL(window)日志在linux 下查看
linux·数据库·windows·sql·日志