如何从mongodb中的listDatabases获取数据库名称?

时间:2018-01-15 12:06:49

标签: php mongodb-php php-mongodb

我在变量

中的mongodb中从下面的查询中获取对象
     $dbases = $this->connection->listDatabases(); 

     var_dump($dbases);       

        object(MongoDB\Model\DatabaseInfoLegacyIterator)#10 (1) { ["databases":"MongoDB\Model\DatabaseInfoLegacyIterator":private]=> array(5) { [0]=> array(3) { ["name"]=> string(3) "MGL" ["sizeOnDisk"]=> float(3596288) ["empty"]=> bool(false) } [1]=> array(3) { ["name"]=> string(10) "SiteStatus" ["sizeOnDisk"]=> float(32768) ["empty"]=> bool(false) } [2]=> array(3) { ["name"]=> string(5) "admin" ["sizeOnDisk"]=> float(32768) ["empty"]=> bool(false) } [3]=> array(3) { ["name"]=> string(6) "config" ["sizeOnDisk"]=> float(12288) ["empty"]=> bool(false) } [4]=> array(3) { ["name"]=> string(5) "local" ["sizeOnDisk"]=> float(73728) ["empty"]=> bool(false) } } } 

我想从这个对象中提取数据库名称,例如MGL,SiteStatus。 请帮我通过php代码提取它们。我试过像

            foreach ($dbases['databases'] as $dbs) 
            {    
                $dbname = $dbs['name'];                              
            }

它不起作用。请帮忙!!!

1 个答案:

答案 0 :(得分:1)

您可以尝试迭代迭代器,如下所示:

foreach($this->connection->listDatabases() as $database)
{
    echo $database->getName();
}

每个$database都是类MongoDB\Model\DatabaseInfo的对象,其方法为getName()