Zend Framework 2 Db getColumns
Zend Framework 2 Db getColumns
'getColumns' 应该 return 到底是什么?如果我使用抽象接口检索 table,看来我可以获得列名的唯一方法是使用元数据 class,我的 IDE 表示已弃用。然而,尽管进行了数小时的搜索,我似乎无法找到任何有关替代其功能的信息。
我认为它可能是 table 网关中的 'getColumns',但每当我在定义的 table.
上调用它时,我总是得到一个空集
class Zend\Db\Metadata\Metadata
实际上已弃用,但功能仍然存在。如果您查看 class,您会发现这条注释:
/**
* @deprecated Use Zend\Db\Metadata\Source\Factory::createSourceFromAdapter($adapter)
*/
class Metadata implements MetadataInterface
{
...
}
因此,要直接实例化 Metadata
class,您必须使用工厂:
// 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;
}
}
'getColumns' 应该 return 到底是什么?如果我使用抽象接口检索 table,看来我可以获得列名的唯一方法是使用元数据 class,我的 IDE 表示已弃用。然而,尽管进行了数小时的搜索,我似乎无法找到任何有关替代其功能的信息。 我认为它可能是 table 网关中的 'getColumns',但每当我在定义的 table.
上调用它时,我总是得到一个空集 class Zend\Db\Metadata\Metadata
实际上已弃用,但功能仍然存在。如果您查看 class,您会发现这条注释:
/**
* @deprecated Use Zend\Db\Metadata\Source\Factory::createSourceFromAdapter($adapter)
*/
class Metadata implements MetadataInterface
{
...
}
因此,要直接实例化 Metadata
class,您必须使用工厂:
// 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;
}
}