I am writing a class that contains an array of other objects that it generates by querying a database. Each instance of this class runs a nearly identical query so my thought was to setup a shared prepared statement handler and each class would simply bind a different variable to it. Here is the code snippet:
class CQuestion
{
    // this is line 16
    static private $sthAns = SPDO::prepare(
        'SELECT * FROM answers WHERE answers.q_id = :qid'
    );
    // constructor, other functions, etc.   
    private function GetAnswers()
    {
        self::$sthAns->bindParam(':qid', $this->m_iQID, PDO::PAR开发者_如何学CAM_INT);
        self::$sthAns->execute();
    }
}
I know this doesn't work because I get the following error:
Parse error: syntax error, unexpected '(', expecting ',' or ';' in C:\xampp\htdocs\mbtest\CQuestion.php on line 16
Does anyone know a way to implement this without having to reset the prepared statement for each instance of the class?
Incase there is any confusion I have wrapped PDO in my own singleton (SPDO) that sets itself through a ini file. Thats why I am accessing prepare through a static reference.
You can't call a method when instantiating an object/class property. You'll need to use a constructor/initializer for that. Try something like this:
class CQuestion
{
    private static $sthAns;
    private static function getSthAns()
    {
        if (!isset(self::$sthAns)) self::$sthAns = SPDO::prepare(
            'SELECT * FROM answers WHERE answers.q_id = :qid'
        );
        return self::$sthAns;
    }
    private function GetAnswers()
    {
        self::getSthAns()->bindParam(':qid', $this->m_iQID, PDO::PARAM_INT);
        self::getSthAns()->execute();
    }
}
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论