使用pdo创建动态数据库连接


php with pdo, create dynamic database connection

我用这个语句创建连接

dbh = new PDO('mysql:host=localhost;dbname=mydb;port=3306;connect_timeout=15', 'root', '');

但是在我的应用程序用户能够改变数据源,所以我需要创建当前数据库连接与服务器信息用户张贴,我尝试这个:

dbh = new PDO('sqlsrv:server=' + $result["servername"] + ';dbname=' + $result["dbname"] + ';port=3306;connect_timeout=15', '' + $result["user"] + '', '' + $result["password"] + '');`

但是失败了。即使我尝试了简单的代码示例得到文档,它也失败了。这是怎么回事,我该怎么做?

首先,您不能将字符串与'+'合并。你必须用'。',你需要为每个数据库连接创建新的PDO连接对象(或设置它存在)在这里我分享我的部分代码这样做:

private function __construct()
    {
        //default database connection
        $this->dbh = new PDO('mysql:host=localhost;dbname=webfilter;port=3306;connect_timeout=15', 'root', '');
        $this->dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $this->dbh->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
        $this->directed = false;
        $this->resultBool = true;
    }
    public static function getConnection()
    {
        $sqlstring = "select * from datasources WHERE ACTIVE =1";
        if (!isset(self::$instance))
        {
            $object = __CLASS__;
            self::$instance = new $object;
        }
        if (true) {
            $request = self::$instance->dbh->prepare($sqlstring);
            if ($request->execute()) {
                if ($result = $request->fetch(PDO::FETCH_ASSOC)) {
                    if ($result["SOFTWARE"] == "mysql") {
                        self::$instance->dbh = null;
                        self::$instance->connectedDbName = "mysql(" . $result["DATABASENAME"] . ")";
                        self::$instance->dbh = new PDO('mysql:host=' . $result["SERVERADDRESS"] . ';dbname=' . $result["DATABASENAME"] . ';port=3306;connect_timeout=15', '' . $result["USERNAME"] . '', '' . $result["PASSWORD"] . '');
                        self::$instance->dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
                        self::$instance->directed = true;
                        self::$instance->resultBool = true;
                    } else if ($result["SOFTWARE"] == "mssql") {
                        self::$instance->dbh = null;//close the existing connection
                        self::$instance->connectedDbName = "mssql(" . $result["DATABASENAME"] . ")";
                        self::$instance->dbh = new PDO('sqlsrv:server=' . $result["SERVERADDRESS"] . ';Database=' . $result["DATABASENAME"] . '', '' . $result["USERNAME"] . '', '' . $result["PASSWORD"] . '');
                        self::$instance->dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
                        self::$instance->dbh->query("use " . $result["DATABASENAME"]);
                        self::$instance->directed = true;
                        self::$instance->resultBool = true;
                    } else if ($result["SOFTWARE"] == "oracle") {
                        self::$instance->connectedDbName = "oracle(" . $result["DATABASENAME"] . ")";
                        self::$instance->dbh = new PDO('odbc:DRIVER=FreeTDS;server=localhost;Database=Dbname', 'username', '!123qwe');
                    }
                    self::$instance->resultBool = true;
                    $temp = self::$instance->dbh->query("select DEVICEID from ethernet LIMIT 1");
                    self::$instance->setDeviceid($temp->fetchColumn());
                    return self::$instance;
                }
                self::$instance->connectedDbName = "default";
                $temp = self::$instance->dbh->query("select DEVICEID from ethernet LIMIT 1");
                self::$instance->setDeviceid($temp->fetchColumn());
                return self::$instance;
            }
        }
        self::$instance->connectedDbName = "default";
        return self::$instance;
    }
    public function getConnectionStatusMessage()
    {
        if ($this->resultBool) {
            return "Connection Successfull" . $this->connectedDbName;
        } else {
            return "Connection Failed:" . $this->resultString;
        }
    }

$dbh = new PDO('sqlsrv:server=' . $result["servername"] . ';dbname=' . $result["dbname"] . ';port=3306;connect_timeout=15', $result["user"], $result["password"]);