服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|

服务器之家 - 数据库 - Mysql - mysql 临时表 cann't reopen解决方案

mysql 临时表 cann't reopen解决方案

2019-12-12 16:54MYSQL教程网 Mysql

MySql关于临时表cann't reopen的问题,本文将提供详细的解决方案,需要了解的朋友可以参考下

当你创建临时表的时候,你可以使用temporary关键字。如: 

复制代码代码如下:

create temporary table tmp_table(name varchar(10) not null,passwd char(6) not null); 


或 

复制代码代码如下:

create temporary table if not exists sp_output_tmp engine= memory select …from … where ID=current_id; 


临时表只在当前连接可见,当这个连接关闭的时候,会自动drop。这就意味着你可以在两个不同的连接里使用相同的临时表名,并且相互不会冲突,或者使用 已经存在的表,但不是临时表的表名。(当这个临时表存在的时候,存在的表被隐藏了,如果临时表被drop,存在的表就可见了)。创建临时表你必须有 
create temporary table 权限。 
下面几点是临时表的限制: 
1、临时表只能用在 memory,myisam,merge,或者innodb 
2、临时表不支持mysql cluster(簇) 
3、在同一个query语句中,你只能查找一次临时表。例如:下面的就不可用 

复制代码代码如下:

mysql> SELECT * FROM temp_table, temp_table AS t2; 
ERROR 1137: Can't reopen table: 'temp_table' 


mysql bug地址:http://bugs.mysql.com/bug.php?id=10327 
如果在一个存储函数里,你用不同的别名查找一个临时表多次,或者在这个存储函数里用不同的语句查找,这个错误都会发生。 
4、show tables 语句不会列举临时表 
你不能用rename来重命名一个临时表。但是,你可以alter table代替: 

复制代码代码如下:

mysql>ALTER TABLE orig_name RENAME new_name; 


临时表用完后要记得drop掉: 

复制代码代码如下:

DROP TEMPORARY TABLE IF EXISTS sp_output_tmp; 

延伸 · 阅读

精彩推荐
  • Mysql数据库的用户帐号管理基础知识

    数据库的用户帐号管理基础知识

    MySQL管理员应该知道怎样通过指定哪些用户可连接到服务器、从哪里进行连接,以及在连接时做什么,来设置MySQL用户账号。MySQL3.22.11引入了两个更容易进行...

    服务器之家2432019-10-15
  • Mysqlmysql删除表中某一字段重复的记录

    mysql删除表中某一字段重复的记录

    一般大家也许会碰到这个问题,大家可以参考下,讲的比较详细 ...

    mysql技术网1722019-10-23
  • MysqlMySQL 加密/压缩函数

    MySQL 加密/压缩函数

    在MySQL中,加密和压缩函数返回二进制串。对其中的许多函数而言,结果可能包含任意的字节值,如果想存储这些结果,你应该使用一个具有varbinary或者b...

    mysql教程网2952019-11-04
  • MysqlMysql5.7修改root密码教程

    Mysql5.7修改root密码教程

    今天小编就为大家分享一篇关于Mysql5.7修改root密码教程,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看...

    炫酷飞扬2132019-06-04
  • MysqlADODB 入门

    ADODB 入门

    1. 前言 ADODB 是 Active Data Objects Data Base 的简称,它是一种 PHP 存取数据库的函式组件。现在 SFS3 系统 (校园自由软件交流网学务系统) 计划的主持人陈莹光老...

    脚本之家2652019-10-16
  • Mysql找到MySQL的优点

    找到MySQL的优点

    假设你是一个Access开发人员,而你想移植一个Access后台到一个本地的MySQL 服务器用于开发和测试。你将维护你自己的解决方案并乐于使用Community Server ...

    mysql教程网2892019-11-01
  • MysqlMySQL用户账户管理和权限管理深入讲解

    MySQL用户账户管理和权限管理深入讲解

    这篇文章主要给大家介绍了关于MySQL用户账户管理和权限管理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习...

    mumengyun1812019-06-14
  • Mysqlmysql5.5 master-slave(Replication)主从配置

    mysql5.5 master-slave(Replication)主从配置

    在主机master中对test数据库进行sql操作,再查看从机test数据库是否产生同步。 ...

    MYSQL教程网3752019-11-21