MySQL 报错:1137 - Can‘t reopen table

MySQL 报错:1137 - Can't reopen table

1. 问题

对临时表查询:

bash 复制代码
select a.ts_code,a.tsnum,b.tsnum from 
	(select t.ts_code ,count(*) tsnum from tmp_table t group by t.ts_code  having count(*) > 20 and count(*)< 50 ) a ,
	(select t.ts_code ,count(*) tsnum from tmp_table t group by t.ts_code  having count(*) > 30 and count(*)< 100 ) b
where a.ts_code=b.ts_code;

报错:

1137 - Can't reopen table: 't'

在正常表中,肯定是可以的。

让人迷惑了一下子。

2.原因

MySQL中出现错误1137 "Can't reopen table "通常是由于在同一个查询中多次引用了同一个临时表。根据MySQL的限制,不能在同一查询中多次引用一个临时表,即使是使用不同的别名,这个限制也适用于存储过程中对临时表的多次引用。

  • 解决方案
    (1)使用不同的临时表:如果你需要在查询中多次使用临时表,可以考虑使用多个不同表名的临时表来存储中间结果。
    (2)使用持久化表:把临时表拷贝到正常表里,使用持久化表(非临时表)来代替临时表,因为持久化表没有这样的限制。
相关推荐
玄同76522 分钟前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码24 分钟前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean25 分钟前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer
那个村的李富贵1 小时前
解锁CANN仓库核心能力:50行代码搭建国产化AIGC图片风格迁移神器
mysql·信息可视化·aigc·cann
小Tomkk1 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
qq_12498707531 小时前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
倒流时光三十年2 小时前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
码农小卡拉2 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
怣502 小时前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx3 小时前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt