Zend Framework 2 Db getColumns

时间:2019-07-08 22:17:43

标签: mysql zend-framework2

“ getColumns”应该返回什么?如果我使用抽象接口检索表,那么看来,获取列名的唯一方法是使用Metadata类,该类是我的IDE所建议的。尽管进行了数小时的搜索,但似乎无法找到任何有关替代其功能的信息。 我以为它可能是表网关中的“ getColumns”,但每次在定义的表上调用它时,总会得到一个空集。

1 个答案:

答案 0 :(得分:1)

RDBMS Metadata documentation

实际上已弃用了类Zend\Db\Metadata\Metadata,但功能仍然存在。如果您在课堂上看一眼,就会发现以下注释:

/**
 * @deprecated Use Zend\Db\Metadata\Source\Factory::createSourceFromAdapter($adapter)
 */
class Metadata implements MetadataInterface
{
   ...
}

因此,要直接实例化Metadata类,必须使用工厂:

// This is deprecated
// $metadata = new \Zend\Db\Metadata\Metadata($adapter);

// This is the correct way to obtain the metadata 
$metadata = \Zend\Db\Metadata\Source\Factory::createSourceFromAdapter($adapter);

// get the table names
$tableNames = $metadata->getTableNames();

foreach ($metadata->getTableNames() as $tableName) {
    echo 'In Table ' . $tableName . PHP_EOL;

    $table = $metadata->getTable($tableName);

    echo '    With columns: ' . PHP_EOL;
    foreach ($table->getColumns() as $column) {
        echo '        ' . $column->getName()
        . ' -> ' . $column->getDataType()
        . PHP_EOL;
    }
}