PolarDB用什么方法可以判断持久连接的dblink是否存在?
我尝试了从pg_stat_activity和pg_foreign_server检索,发现都没有我想要的东西,网上资料也很少,不知道还有什么办法能用了。
在 PolarDB 中,对于 PostgreSQL 版本,判断持久连接的数据库链接(dblink)是否存在,主要是查看数据库系统表中关于dblink的相关配置信息,而不是通过pg_stat_activity
或pg_foreign_server
这两个视图。
持久连接的dblink在PostgreSQL中是通过dblink
扩展实现的,检查dblink主要查看pg_extension
表(确认dblink扩展是否启用)以及pg_database_dblink
系统表(查看具体dblink配置)。
以下是如何检查dblink扩展是否启用以及查看dblink配置的方法:
检查dblink扩展是否已安装并启用:
SELECT EXISTS (
SELECT 1 FROM pg_available_extensions WHERE name = 'dblink'
) AS is_available,
EXISTS (
SELECT 1 FROM pg_extension WHERE extname = 'dblink'
) AS is_installed;
如果is_installed
为true,说明dblink扩展已安装在当前数据库中。
列出所有已配置的dblink连接:
-- PostgreSQL标准dblink并没有持久连接的概念,这里假设你是指dblink配置
SELECT * FROM dblink_ls();
上述命令适用于检查当前数据库中的dblink配置,但请注意,dblink配置并非持久存储,每次会话结束后,dblink配置也会失效。
在PolarDB中,要判断持久连接的dblink是否存在,您可以尝试以下方法:
information_schema.tables
或pg_catalog.pg_tables
,看是否有与dblink相关的表。这可以帮助您了解数据库中是否有dblink相关的对象。dblink_ora_connect()
函数用于与Oracle数据库建立连接。版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
PolarDB 分布式版 (PolarDB for Xscale,简称“PolarDB-X”) 采用 Shared-nothing 与存储计算分离架构,支持水平扩展、分布式事务、混合负载等能力,100%兼容MySQL。 2021年开源,开源历程及更多信息访问:OpenPolarDB.com/about