无法在类内的try块中使用return


unable to use return in a try-block inside a class

我在实现以下方法时遇到问题:

private function query($statement, $params = array(), $name = ""){
    try{
        $this->prepare($statement, $name);
    }catch (Exception $e){
        echo 'Exception: ',  $e->getMessage(), "'n";
    }   
    try{
        return $this->execute($name, $params);
    }catch (Exception $e){
        echo 'Exception: ',  $e->getMessage(), "'n";
    }
}

第二个try块应该返回另一个调用的方法的值。我这样称呼它:

$resultset = $db->select('SELECT * FROM tabelle WHERE "ID" > $1', array(1));
var_dump($resultset);

并获得一个NULL
如果我在try块内var_dump值,我会得到一个结果:

private function query($statement, $params = array(), $name = ""){
    try{
        $this->prepare($statement, $name);
    }catch (Exception $e){
        echo 'Exception: ',  $e->getMessage(), "'n";
    }   
    try{
        var_dump($this->execute($name, $params));
    }catch (Exception $e){
        echo 'Exception: ',  $e->getMessage(), "'n";
    }
}

array(3){["ID"]=>string(1)"2"["name"]=>string(13)"name1"["time"]=>string(26)"2012-09-11 20:23:38.854918"}空

我做错了什么?

编辑$db->select和发布方法之间的部分:

public function select($statement, $params = array(), $name){
  $this->setQueryType("select"); // just a setter
  return $this->query($statement, $params, $name);
}

尝试存储execute的返回值,并在方法结束时返回,看看它是否有效?

private function query($statement, $params = array(), $name = ""){
  $return = false;
  try{
    $this->prepare($statement, $name);
    $return = $this->execute($name, $params);
  }
  catch (Exception $e){
    echo 'Exception: ',  $e->getMessage(), "'n";
  }
  return $return;
}