dbeaver创建create临时表之后查询不到问题排查

前提:一共有三张表,表一和表二和表三

需求是要拿表一和表二的查询结果和表三进行关联查询

所以写了sql如下

CREATE TEMPORARY TABLE temp_reports AS

SELECT gr.*,

sd.dept_id,

sd.parent_id

FROM pc_amount_report gr

LEFT JOIN sys_dept sd ON gr.comp_id = sd.dept_id

WHERE gr.report_year = 2022

AND gr.report_month = 5

AND (

sd.dept_id = (

SELECT dept_id

FROM sys_dept

WHERE dept_name = '某某某

)

OR sd.parent_id = (

SELECT dept_id

FROM sys_dept

WHERE dept_name = '某某某'

)

);

SELECT pt.* FROM pc_amount_report_task pt

LEFT JOIN temp_reports tr

ON pt.pc_amount_report_task_id = tr.pc_amount_report_task_id

AND pt.plan_id = tr.plan_id

and pt.approval_company_code=tr.approval_company_code

and pt.approval_company_name=tr.approval_company_name

and pt.report_year=tr.report_year

可是执行完一之后,用select * from 临时表temp_reports ,可以查处来数据,然后在数据库搜索框搜索表名却一直无法搜索出来,所以导致第2段sql无法执行

最后发现竟然是没有建表的权限,也真是无语

如果你和我一样,无法执行sql,可以参考下面的原因进行排查

报错信息 "already exists" 通常意味着你尝试创建的临时表已经存在于数据库中。

解决方法:

  1. 检查表名:确保你输入的临时表名称是唯一的,并且没有与数据库中现有的表名冲突。

  2. 检查会话:如果你在不同的数据库会话中执行创建操作,确保你在正确的会话中查找表。

  3. 清理会话:如果确认表名没有问题,尝试清理当前的数据库会话,然后重新创建临时表。

  4. 权限问题:确认你有足够的权限在数据库中创建临时表。

  5. 语法检查:确认SQL语句语法正确,没有遗漏关键字或错误的语法结构。

如果你确认临时表不存在,但仍然收到错误消息,可以尝试以下步骤:

  • 刷新数据库视图。

  • 重启数据库管理工具(如DBeaver)。

  • 重启数据库服务。

如果这些步骤都不能解决问题,可能需要联系数据库管理员或查看数据库日志以获取更多信息。

相关推荐
IT龟苓膏4 小时前
Redis 数据类型底层原理:SDS、quicklist、intset、skiplist、Bitmap、HyperLogLog 一篇讲清
数据库·redis·skiplist
流星白龙4 小时前
【MySQL高阶】19.变更缓冲区,自适应哈希索引,日志缓冲区
数据库·windows·mysql
晴天¥4 小时前
Oracle中的监听配置与管理(动态、静态监听配置对比以及listener.ora和tnsnames.ora)
数据库·oracle
持敬chijing5 小时前
Web渗透之SQL注入-文件读写-木马植入
sql·安全·web安全·网络安全·安全威胁分析
瀚高PG实验室5 小时前
python连接HGDB超时
数据库·瀚高数据库·highgo
jnrjian5 小时前
ddl_lock_timeout 设置 read only table 通过view 实现细粒度依赖
sql·oracle
闪电悠米6 小时前
黑马点评-Redisson-01_why_redisson
java·服务器·网络·数据库·缓存·wpf
Counter-Strike大牛6 小时前
SpringBoot2.7.10+MyBatisPlus实现MySQL+DM双数据库切换
数据库·mysql
dllxhcjla7 小时前
Redis
数据库·redis·缓存
睡不醒男孩0308237 小时前
数据库高可用运维实操指南:基于CLup的PostgreSQL生产环境自动化管理
运维·数据库·postgresql