无法从zf3中的ResultSet对象数组中获取数据
问题描述:
我正在使用zend framework3并使用数据库的Mysql驱动程序。 我使用下面的代码来获取数据:无法从zf3中的ResultSet对象数组中获取数据
$con = $this->adapter;
$select = $this->sql->select();
$select->from('nav_menu');
$selectString = $this->sql->getSqlStringForSqlObject($select);
$results = $con->query($selectString, $con::QUERY_MODE_EXECUTE);
$resultSet = new ResultSet();
$resultSet->initialize($results);
当我的var_dump这个数据我得到如下结果:
Zend\Db\ResultSet\ResultSet Object
(
[allowedReturnTypes:protected] => Array
(
[0] => arrayobject
[1] => array
)
[arrayObjectPrototype:protected] => ArrayObject Object
(
[storage:ArrayObject:private] => Array
(
)
)
[returnType:protected] => arrayobject
[buffer:protected] =>
[count:protected] =>
[dataSource:protected] => Zend\Db\ResultSet\ResultSet Object
(
[allowedReturnTypes:protected] => Array
(
[0] => arrayobject
[1] => array
)
[arrayObjectPrototype:protected] => ArrayObject Object
(
[storage:ArrayObject:private] => Array
(
)
)
[returnType:protected] => arrayobject
[buffer:protected] => -1
[count:protected] =>
[dataSource:protected] => Zend\Db\Adapter\Driver\Mysqli\Result Object
(
[resource:protected] => mysqli_result Object
(
[current_field] => 0
[field_count] => 8
[lengths] =>
[num_rows] => 15
[type] => 0
)
[isBuffered:protected] => 1
[position:protected] => 0
[numberOfRows:protected] => -1
[currentComplete:protected] =>
[nextComplete:protected] =>
[currentData:protected] =>
[statementBindValues:protected] => Array
(
[keys] =>
[values] => Array
(
)
)
[generatedValue:protected] => 0
)
[fieldCount:protected] => 8
[position:protected] => 0
)
[fieldCount:protected] =>
[position:protected] => 0
)
我得到一个错误,当我这个迭代来得到的值如下:
foreach ($resultSet as $key => $value) {
$array[$i]['id'] = $value->id;
$array[$i]['name'] = $value->name;
$array[$i]['label'] = $value->label;
$array[$i]['route'] = $value->route;
$array[$i]['parent_id'] = $value->parent_id;
$i++;
}
我不是在哪里我错了。虽然有num_rows是15.这是在ZF2罚款。 任何人的任何帮助表示赞赏。
我尝试了很多,发现如果与
$statement = $this->sql->prepareStatementForSqlObject($select);
$results = $statement->execute();
替换代码
$selectString = $this->sql->getSqlStringForSqlObject($select);
$results = $con->query($selectString, $con::QUERY_MODE_EXECUTE);
然后我得到的result.But我的问题是,为什么我没有通过
得到结果$selectString = $this->sql->getSqlStringForSqlObject($select);
$results = $con->query($selectString, $con::QUERY_MODE_EXECUTE);
答
getSqlStringForSqlObject
从版本2.4开始已弃用。但我不知道这是否是它不再工作的原因。
根据docs有2种方法。随着准备语句,它使用的是完全相同的:
$statement = $sql->prepareStatementForSqlObject($select);
$results = $statement->execute();
与执行查询,这你可能寻找:
$selectString = $sql->buildSqlString($select);
$results = $adapter->query($selectString, $adapter::QUERY_MODE_EXECUTE);
thanx的clearification。 –
你有什么想法如何调用程序。我正在使用此代码 $ results = $ con> query('CALL'fetching_menu'(?)',$ spParams); \t \t $ resultSet = new ResultSet; \t \t $ resultSet-> initialize($ results); 其中$ spParams = array('backend'); 我收到一个错误。 –
我解决了这个问题。我用 $ spParams = ['backend']; \t \t $ statement = $ con> createStatement('CALL'fetching_menu'(?)',$ spParams); \t \t \t \t $ result = $ statement-> execute(); \t \t \t \t $ resultSet = new ResultSet; \t \t \t $ resultSet-> initialize($ result); –