PHP MSSQL PDO获取表名?

时间:2015-04-23 07:59:37

标签: php sql-server pdo

我希望使用PDO(MSSQL)从远程数据库获取表数组  我注意到我不能使用mysql查询命令,任何建议如何使用pdo或mssql从mssql数据库获取所有表信息?

我能够连接:

try {
    $hostname = $myServer;
    $port = 10060;
    $dbname = $myDB ;
    $username = $myUser ;
    $pw = $myPass;
    $dbh = new PDO ("mssql:host=$hostname;dbname=$dbname","$username","$pw");
  } catch (PDOException $e) {
    echo "Failed to get DB handle: " . $e->getMessage() . "\n";
    exit;
  }

但无法获取数据:

$q = $dbh->prepare("DESCRIBE");
$q->execute();
$table_fields = $q->fetchAll(PDO::FETCH_COLUMN);
print_r($table_fields);

  } catch (PDOException $e) {
    echo "Failed to get DB handle: " . $e->getMessage() . "\n";
    exit;
  }

我使用的用户权限只有read权限

1 个答案:

答案 0 :(得分:2)

查询information_Schema。

select Table_Name, table_type from information_schema.tables

您可以使用columns表获取列的名称+数据类型等。

select TABLE_SCHEMA, TABLE_NAME, COLUMN_NAME, data_type, CHARACTER_MAXIMUM_LENGTH 
from INFORMATION_SCHEMA.COLUMNS