1

我从以下查询中的 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'];                              
            }

它不工作。请帮忙!!!

4

1 回答 1

2

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

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

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

于 2018-01-15T13:13:20.993 回答