pgAdmin4如何查看当前的scheme默认是哪个

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核8GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: pgAdmin4如何查看当前的scheme默认是哪个

在pgAdmin 4中,查看当前的schema默认是哪个,通常涉及到检查数据库的search_path设置,因为search_path决定了在没有明确指定schema的情况下,系统将会在哪个schema中查找对象。以下是一步一步的指南,帮助你查看当前的默认schema:


1.打开pgAdmin 4并连接到数据库:

启动pgAdmin 4。

在左侧的对象浏览器中,找到你想要检查的数据库,并连接到它。


2.查询当前的search_path:

在pgAdmin 4的查询工具中,打开一个新的查询窗口。

输入以下SQL命令来查看当前的search_path设置:


sql复制代码
 SHOW search_path;

执行查询。


1;解读查询结果:


查询结果将显示当前的search_path,这是一个由schema名称组成的列表,用逗号分隔。

列表中的第一个schema通常是默认的schema,因为在没有指定schema的情况下,PostgreSQL会首先在这个schema中查找对象。


2.注意事项:


search_path也可以在会话级别或数据库级别进行设置。在会话级别设置会影响当前会话,而在数据库级别设置会影响连接到该数据库的所有会话。


你可以使用SET search_path TO schema_name;命令在会话级别更改search_path,或使用ALTER DATABASE database_name SET search_path TO schema_name;命令在数据库级别更改它。



总结:

通过查询SHOW search_path;,你可以轻松地找到当前的默认schema。这个设置决定了在不指定schema时,PostgreSQL会在哪个schema中查找对象。


当你在 PostgreSQL 的 search_path 设置中看到 $user, public 这样的值时,它们代表了特定的 schema 搜索顺序。这里的 $user 和 public 有特定的含义:


1.$user:

这表示与当前数据库用户同名的 schema。例如,如果有一个名为 john 的用户,并且存在一个名为 john 的 schema,那么 $user 将指向 john 这个 schema。这是 PostgreSQL 提供的一个方便的特性,允许每个用户有自己的私有 schema。


2.public:

public 是一个在所有 PostgreSQL 数据库中默认存在的特殊 schema。任何用户都可以在其中创建对象(如表、视图、函数等),除非有特定的权限设置阻止他们这样做。


当你在 search_path 中看到 "$user",public 这样的设置时,它表示当查询一个对象(如表)时,PostgreSQL 会首先在当前用户的同名 schema 中查找,如果找不到,则会在 public schema 中查找。


例如,如果你有一个名为 john 的用户,并且你尝试查询一个名为 my_table 的表,PostgreSQL 会首先在 john schema 中查找 my_table,如果找不到,则会在 public schema 中查找。


你可以使用以下 SQL 命令来查看当前的 search_path 设置:


sql复制代码
 SHOW search_path;


如果你想要更改 search_path,你可以使用 SET 命令,例如:


sql复制代码
 SET search_path TO "$user", public;


这将把当前会话的 search_path 设置为首先在当前用户的同名 schema 中查找,然后在 public schema 中查找。注意,这个更改只会影响当前的会话。如果你想要永久地更改一个数据库的 search_path,你需要修改数据库的配置或使用 ALTER DATABASE 命令。


相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍如何基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
前端开发 Java 调度
【JavaEE进阶】 拦截器(DispatcherServlet)源码简介
【JavaEE进阶】 拦截器(DispatcherServlet)源码简介
|
11月前
|
JavaScript 开发者
vue指令的开发看这篇文章就够了!超详细,赶快收藏!
【10月更文挑战第8天】vue指令的开发看这篇文章就够了!超详细,赶快收藏!
vue指令的开发看这篇文章就够了!超详细,赶快收藏!
|
JavaScript 关系型数据库 数据库
PostgreSQL支持哪些编程语言?
【8月更文挑战第5天】PostgreSQL支持哪些编程语言?
479 8
|
Java Nacos 开发工具
【Nacos】心跳断了怎么办?!8步排查法+实战代码,手把手教你解决Nacos客户端不发送心跳检测问题,让服务瞬间恢复活力!
【8月更文挑战第15天】Nacos是一款广受好评的微服务注册与配置中心。然而,“客户端不发送心跳检测”的问题时有发生,可能导致服务实例被视为离线。本文介绍如何排查此类问题:确认Nacos服务器地址配置正确;检查网络连通性;查看客户端日志;确保Nacos SDK版本兼容;调整心跳检测策略;验证服务实例注册状态;必要时重启应用;检查影响行为的环境变量。通过这些步骤,通常可定位并解决问题,保障服务稳定运行。
757 0
|
SQL 关系型数据库 数据库
PostgreSQL常用命令,启动连接,pg_dump导入导出
PostgreSQL常用命令,启动连接,pg_dump导入导出
|
分布式计算 Python
【python笔记】高阶函数map、filter、reduce
【python笔记】高阶函数map、filter、reduce
212 0
|
缓存 NoSQL Java
Springboot整合缓存
Springboot整合缓存
416 0
Springboot整合缓存
|
机器学习/深度学习 数据可视化 数据挖掘
R语言实现CNN(卷积神经网络)模型进行回归数据分析
R语言实现CNN(卷积神经网络)模型进行回归数据分析
|
消息中间件
Error: unable to perform an operation on node ‘rabbit@PC-201712061807‘. Please see diagnostics infor
Error: unable to perform an operation on node ‘rabbit@PC-201712061807‘. Please see diagnostics infor
575 0
Error: unable to perform an operation on node ‘rabbit@PC-201712061807‘. Please see diagnostics infor