在Oracle中创建了某张表,确在all_tables表里面查不到该表

当使用SQLPLUS查询表时,可能由于表不在当前用户创建的容器中,或者查询时所在的容器错误(如在CDB而非PDB)导致无法找到表。解决方法包括检查当前容器(使用SHOWCON_NAME)和切换到正确容器(如使用ALTERSESSIONSETCONTAINER=orclpdb)。建议先确认容器状态,再通过查询ALL_TABLES来定位表信息。
摘要由CSDN通过智能技术生成

除了普遍提到的,所查询的表可能不是当前用户所创建,即用户权限问题之外,还有一种可能:

创建表的时候可能在CDB上,查询时如果另外一个链接在PDB上,那么也查不到这张表。

就常用的SQLPLUS来说,默认连接到CDB上,需要经由

ALTER SESSION SET CONTAINER=orclpdb;

方才切换到PDB上。

所以碰到这种情况先通过以下语句确认container为宜:

show con_name;

再通过

select table_name(等字段) from all_tables;进行查询 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值