0

こんにちは、一時テーブルを使用しています。一時テーブル ストレージ エンジン (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]);
}

しかし、DB で物理テーブルのストレージ エンジンを見つけようとすると、同じコードが機能しますか?

どんな助けでも大歓迎です.!! ありがとうございました。

4

2 に答える 2

1

残念ながら

現在、[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'];
于 2013-04-30T09:21:38.473 に答える