Array
(
)

Erro ao fazer read dinâmico com PHP

PHP
Wesley Jonas
   - 19 jun 2016

Quando eu tenho executar o código abaixo retorna a seguinte mensagem: Fatal error: Uncaught Error: Cannot use object of type stdClass as array in C:\Apache24\htdocs\montesinai\index.php:116 Stack trace: #0 {main} thrown in C:\Apache24\htdocs\montesinai\index.php on line 116.
Por favor, me ajudem.
#Código
<?php
$Read = new Read;
$Read->ExeRead('cliente');
echo $Read->getResult()[0]['email'];
?>
Classe Read

<?php
<?php
/**
* <b>Read.class:</b>
* Classe responsável por leituras genéticas no banco de dados!
*
* @copyright (c) 2014, Robson V. Leite UPINSIDE TECNOLOGIA
*/
class Read extends Conn {
private $Select;
private $Places;
private $Result;
/** @var PDOStatement */
private $Read;
/** @var PDO */
private $Conn;
/**
* <b>Exe Read:</b> Executa uma leitura simplificada com Prepared Statments. Basta informar o nome da tabela,
* os termos da seleção e uma analize em cadeia (ParseString) para executar.
* @param STRING $Tabela = Nome da tabela
* @param STRING $Termos = WHERE | ORDER | LIMIT :limit | OFFSET :offset
* @param STRING $ParseString = link={$link}&link2={$link2}
*/
public function ExeRead($Tabela, $Termos = null, $ParseString = null) {
if (!empty($ParseString)):
parse_str($ParseString, $this->Places);
endif;
$this->Select = "SELECT * FROM {$Tabela} {$Termos}";
$this->Execute();
}
/**
* <b>Obter resultado:</b> Retorna um array com todos os resultados obtidos. Envelope primário númérico. Para obter
* um resultado chame o índice getResult()[0]!
* @return ARRAY $this = Array ResultSet
*/
public function getResult() {
return $this->Result;
}
/**
* <b>Contar Registros: </b> Retorna o número de registros encontrados pelo select!
* @return INT $Var = Quantidade de registros encontrados
*/
public function getRowCount() {
return $this->Read->rowCount();
}
public function FullRead($Query, $ParseString = null) {
$this->Select = (string) $Query;
if (!empty($ParseString)):
parse_str($ParseString, $this->Places);
endif;
$this->Execute();
}
/**
* <b>Full Read:</b> Executa leitura de dados via query que deve ser montada manualmente para possibilitar
* seleção de multiplas tabelas em uma única query!
* @param STRING $Query = Query Select Syntax
* @param STRING $ParseString = link={$link}&link2={$link2}
*/
public function setPlaces($ParseString) {
parse_str($ParseString, $this->Places);
$this->Execute();
}
/**
* ****************************************
* *********** PRIVATE METHODS ************
* ****************************************
*/
//Obtém o PDO e Prepara a query
private function Connect() {
$this->Conn = parent::getConn();
$this->Read = $this->Conn->prepare($this->Select);
$this->Read->setFetchMode(PDO::FETCH_OBJ);
}
//Cria a sintaxe da query para Prepared Statements
private function getSyntax() {
if ($this->Places):
foreach ($this->Places as $Vinculo => $Valor):
if ($Vinculo == 'limit' || $Vinculo == 'offset'):
$Valor = (int) $Valor;
endif;
$this->Read->bindValue(":{$Vinculo}", $Valor, ( is_int($Valor) ? PDO::PARAM_INT : PDO::PARAM_STR));
endforeach;
endif;
}
//Obtém a Conexão e a Syntax, executa a query!
private function Execute() {
$this->Connect();
try {
$this->getSyntax();
$this->Read->execute();
$this->Result = $this->Read->fetchAll();
} catch (PDOException $e) {
$this->Result = null;
WSErro("<b>Erro ao Ler:</b> {$e->getMessage()}", $e->getCode());
}
}
}