php - 如何在 PhpStorm 中编写 PHPDoc 以返回 PDO 和 MySQLi 连接

标签 php return phpstorm phpdoc

我已经编写了一个函数来简化数据库连接,并能够通过 PDO 或 MySQLi 选项进行连接。 目前我正在为 PHPDov @return 属性苦苦挣扎。

我已经在 PhpStorm 中找到了 PDO 方法的正确亮点,但我不知道如何使这两个选项的工作类似。下面的代码可能会更好地解释它。

这是我的 dbCon.php 函数:

<?php

# defining the root directory as constant
define('__ROOT__', dirname($_SERVER['DOCUMENT_ROOT']));

/**
 * @param $db
 * @param $conType
 * @return PDO[]
 */

function dbCon($db, $conType)
{
# parse the data from db.ini where $db is database name
$_con = parse_ini_file(__ROOT__ . '/db.ini');

# set prefix if required by hosting to have one
$pre = 'database_';

# list parameters via variables
$_host = $_con[$db . '_ht'];
$_user = $pre . $_con[$db . '_un'];
$_database = $pre . $_con[$db . '_db'];
$_password = $_con[$db . '_pw'];

# PDO attributes
$_pdo_attr = [
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
    PDO::ATTR_EMULATE_PREPARES => false,
    PDO::ERRMODE_WARNING // development mode only
];

# define dbCon variable;
$_dbCon = false;

# set PDO or MYSQLI connection
switch ($conType) {
    case 'pdo':
        try {
            ${$db . '_pdo'} = new PDO ("mysql:host=$_host;dbname=$_database; charset=utf8", $_user, $_password, $_pdo_attr);
            $_dbCon = ${$db . '_pdo'};
            $_dbSts = ${$db . '_pdo'}->getAttribute(PDO::ATTR_CONNECTION_STATUS);
        } catch (PDOException $e) {
            $_dbSts = false;
        }
        break;
    case 'mysqli':
        ${$db . '_mysqli'} = new mysqli($_host, $_user, $_password, $_database);
        if (${$db . '_mysqli'}->connect_error) $_dbSts = false;
        else $_dbSts = explode('  ', mysqli_stat(${$db . '_mysqli'})); $_dbCon = ${$db . '_mysqli'};
        break;
    default:
        $_dbSts = false; // error case
        break;
}
# output
return ["dbSts" => $_dbSts,
        "dbCon" => $_dbCon];
}

所以,正如你所看到的......

/**
 * @param $db
 * @param $conType
 * @return PDO[]
*/

..这对于返回 PDO 数组很有效,但由于该函数允许切换到 MySQLi,我希望这些方法也能突出显示。

最佳答案

如果您希望您的函数返回多种类型,只需在它们之间放置一个管道即可。我不知道 mysqli 的具体返回类型是什么,但你会想要这样的东西

@return PDO[]|MySQLi

https://docs.phpdoc.org/references/phpdoc/tags/return.html

关于php - 如何在 PhpStorm 中编写 PHPDoc 以返回 PDO 和 MySQLi 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57957377/

相关文章:

javascript - PhpStorm HTML 检查问题

phpstorm - phpStorm 7更新docblock

php - 使用 foreach 循环上的准确数据更新特定行 Codeigniter

java - 如何在Java中对 "either or"类的返回类型进行建模?

javascript - 未捕获的语法错误 : Unexpected token return - still no answer?

JavaScript 函数总是返回 false

phpstorm - 类存在多个定义

javascript - 如何使用 Javascript 从菜单栏获取值

php - 如何在同一个页面中有两种不同的样式

php - 为什么这两个 Count 返回相同的数字?