PhpStorm PDOStatement警告

时间:2016-04-12 12:51:16

标签: php pdo phpstorm

考虑以下课程:

class output_Home {
    public $app;
    public $forums;

    function __construct ($app) {
        // main app class containing db, settings, etc
        $this->app = $app;

        // populate class property arrays for use in template
        $this->setForums();
    }

    function setForums () {
        /*
         * select all forum data, dump into $this->forums array
         * fields:
         *      id, name, slug, description, order,
         *      total_threads, total_posts,
         *      last_post_id, last_post_date, last_poster_id, last_poster_username, last_poster_avatar
         */
        $sql = "select f.*,
                p.id as last_post_id, p.date_created as last_post_date,
                u.id as last_poster_id, u.username as last_poster_username, u.avatar as last_poster_avatar,
                (select count(*) from `threads` where `id_forum`=f.id) as total_threads,
                (select count(*) from `posts` where `id_forum`=f.id) as total_posts
                from `forums` as f
                left join `posts` as p on (p.id = (select `id` from `posts` where `id_forum`=f.id order by `date_created` desc limit 1))
                left join `users` as u on (u.id = p.id_user)
                order by f.order asc";
        $stm = $this->app->db->prepare($sql);
        $stm->execute();
        $this->forums = $this->app->sanitizer->action('sanitize', $stm->fetchAll());
    }
}

这是我的object_App课程:

class object_App {
    public $db;

    function __construct () {
        // create database "db" connection
        $this->db = new PDO('mysql:host='.DB_HOST.';dbname='.DB_NAME, DB_USER, DB_PASS);
        $this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $this->db->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
    }
}

以下是将$this->app传递给output_Home类的方式:

$app = new object_App();
$home = new output_Home($app);

$app属性包含一个名为db的属性,它是一个PDO对象。请特别注意$stm变量。

我的问题是我收到来自PhpStorm的警告,声称在课堂上找不到$stm->execute()等方法。当然,他们不是,因为他们是PDOStatements

我只是想知道是否有一种方法可以正确地消除警告,而不是在我制作的每一个PHPDocs之上使用$stm,因为我会在几个中做出相当多的不同的类方法,我不希望代码中到处都有PHPDocs

任何帮助都将不胜感激。

2 个答案:

答案 0 :(得分:2)

1。$db提供正确的类型提示。在你的特殊情况下,这可能不是100%必要的,但更好的是它(这是一次性工作)

class object_App {
    /** @var \PDO */
    public $db;
    ...

一般情况下,IDE可以找出$db是什么,因为你有$this->db = new PDO(...);并且它位于__construct()(2个重要因素)..但最好是在更安全的一面使用合适的类型暗示。如果这样的行将被放置在一些普通的方法中(例如createDBConnection()或者某种东西),那么IDE就不会做那么昂贵的额外情报。

2。最重要的是 - 为您的$app提供类型提示。传递此参数的方式不会给IDE提供任何提示。

可以这样做(IDE应该弄清楚其余部分):

function __construct (object_App $app) {

或者以与#1相同的方式更好:

class output_Home {
    /** @var object_App */
    public $app;

甚至更好 - 将它们组合在一起:

class output_Home {
    /** @var object_App */
    public $app;

    function __construct (object_App $app) {
    ...

答案 1 :(得分:0)

除非PHPStorm知道方法返回的对象类型,否则无法知道该对象可用的方法。

你有3个选择:

1)如你所说,使用快速的phpdoc告诉phpstorm它是什么(你只需要在代码块中执行一次:

/** @var SomeObject $stm */
$stm = $this->app->db->prepare($sql);

2)完全压制警告

查找

设置>编辑器>检查

然后在PHP>下取消undefined method。未定义。

3)如果您控制了被调用的方法:

确保在方法的phpdoc中包含返回类型,PHPStorm将使用它来确定它所需的内容。

/**
* @return SomeObject
*/
public function someFunction() {
   // some stuff
}