2013-04-30 100 views
0

嗨,我用臨時表工作,我想知道臨時表的存儲引擎(InnoDB的,MyISAM的....)如何找到MySQL的臨時表的存儲引擎

我使用下面的代碼找到但它沒有顯示我的存儲引擎。

$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

我得到了錯誤:E_TOO_MANY_CAPITAL_LETTERS。 – Jocelyn 2013-04-30 09:09:01

+0

,但我的物理表「ENGINE:InnoDB」 – TomPHP 2013-04-30 09:12:13

回答

1

Unfortunately

Currently, the [INFORMATION_SCHEMA.]TABLES table does not list TEMPORARY tables.

我勸解析的SHOW CREATE TABLE temporary_table;

結果只提取這個返回值的發動機:

$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']; 
+0

嗨!犛牛!感謝您的回答..但我只想知道存儲引擎。我制定了你的查詢,它提供了表格的所有細節。但我希望單獨使用存儲引擎。有沒有其他方法? – TomPHP 2013-04-30 09:25:01

+0

那麼,用一點正則表達修補,你應該能夠提取所需的信息。如果時間允許,我會回來一個例子。 – RandomSeed 2013-04-30 09:27:28

+0

您好我現在用的是下面的查詢創建臨時表CREATE .: TEMPORARY TABLE csv_import( ID INT, entitiy_id INT, attribute_id INT, 值TEXT )引擎的MyISAM我想,以確保該表中創建MyISAM數據。 – TomPHP 2013-04-30 09:27:51

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'` 
+0

嗨Kami得到以下答案我收到以下錯誤:Sql錯誤:information_schema中的未知表'temporary_tables' – TomPHP 2013-04-30 09:19:10

+0

這可能適用於另一個數據庫引擎,但我擔心我發現MySQL中沒有提及'information_schema.temporary_tables'表。你是指MySQL的[Percona](味精)嗎? – RandomSeed 2013-04-30 09:22:43

+0

您好我現在用的是下面的查詢創建臨時表:CREATE TEMPORARY TABLE csv_import( ID INT, entitiy_id INT, attribute_id INT, 值TEXT )引擎的MyISAM我想,以確保該表中創建MyISAM數據。 – TomPHP 2013-04-30 09:28:31