如何查找MySQL临时表存储引擎

时间:2013-04-30 09:04:26

标签: php mysql database innodb myisam

您好我正在使用Temporary表,我想知道临时表存储引擎(InnoDB,MyISAM ....)

我正在使用以下代码查找,但它没有向我显示存储引擎。

$engine="SELECT ENGINE FROM information_schema.TABLES WHERE TABLE_SCHEMA='test' AND `TABLE_NAME`='temporary_table'";
$export = mysql_query($engine, $connection) or die ("Sql error : ".mysql_error());
while ($row = mysql_fetch_array($export, MYSQL_BOTH)) {
    printf ("ENGINE: %s ---", $row[0]);
}

但是当我尝试在我的数据库中找到物理表的存储引擎时,相同的代码正在工作吗?

非常感谢任何帮助。!!谢谢。

2 个答案:

答案 0 :(得分:1)

Unfortunately

  

目前,[INFORMATION_SCHEMA。] TABLES表未列出TEMPORARY表。

我建议解析SHOW CREATE TABLE temporary_table;

的结果

仅提取此返回值的ENGINE:

$rset = mysql_query('SHOW CREATE TABLE temporary_table;')
$row = mysql_fetch_array($rset, MYSQL_BOTH);
preg_match('/ENGINE\=(?P<engine>\w+)/', $row[1], $matches);
echo $matches['engine'];

答案 1 :(得分:0)

您需要搜索临时表存储information_schema.temporary_tables或全局临时表存储information_schema.global_temporary_tables

尝试

`SELECT ENGINE FROM information_schema.temporary_tables WHERE TABLE_SCHEMA='test' AND `TABLE_NAME`='temporary_table'`