Zend Framework 2 Db getColumns - PullRequest
       21

Zend Framework 2 Db getColumns

0 голосов
/ 09 июля 2019

Что именно должен возвращать getColumns? Если я получаю таблицу с использованием абстрактного интерфейса, кажется, что единственный способ получить имена столбцов - использовать класс метаданных, который, как говорит моя IDE, устарел. Тем не менее, несмотря на часы поиска, я не могу найти информацию о том, что заменяет его функциональность. Я думал, что это может быть 'getColumns' в шлюзе таблицы, но я всегда получаю пустой набор каждый раз, когда вызываю его для определенной таблицы.

1 Ответ

1 голос
/ 09 июля 2019

Документация метаданных СУБД

Класс 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;
    }
}
...