簡體   English   中英

如何將mysql轉換為PDO連接?

[英]how can i transform mysql to PDO connection?

如何將下面的mysql代碼轉換為pdo連接? 因為我有一些網絡問題。

$gaSql['user'] = "root";
$gaSql['password'] = "";
$gaSql['db'] = "test";
$gaSql['server'] = "localhost";

// DB connection
function dbinit(&$gaSql) {

// if error  rezults 500
function fatal_error($sErrorMessage = '') {
header($_SERVER['SERVER_PROTOCOL'] .' 500 Internal Server Error');
die($sErrorMessage);
}

// connecting to mysql
if ( !$gaSql['link'] = @mysql_connect($gaSql['server'], $gaSql['user'],   $gaSql['password']) ) {
fatal_error('Could not open connection to server');
}

// select the DB
if ( !mysql_select_db($gaSql['db'], $gaSql['link']) ) {
fatal_error('Could not select database');
}
}

正確的PDO數據庫連接

<?php

    $host = '127.0.0.1';
    $db   = 'your db';
    $user = 'root';
    $pass = '';
    $charset = 'utf8';

    $dsn = "mysql:host=$host;dbname=$db;charset=$charset";
    $options = [
            PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
            PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
            PDO::ATTR_EMULATE_PREPARES   => false,
            ];


$dbh = new PDO($dsn, $user, $pass, $options);

?>

參考: https : //phpdelusions.net/pdo

我在所有pdo連接中都使用了它,效果很好

您可以嘗試這樣的事情:

try {
    $pdo = new PDO('mysql:host=' . $gaSql['server'] . ';dbname=' . $gaSql['db'], $gaSql['user'], $gaSql['password']);
} catch (PDOException $ex) {
    if ($ex->getCode() == 1049) {
        throw new Exception('Unknown Database: ' . $gaSql['db']);
    } elseif ($ex->getCode() == 1045) {
        throw new Exception('Wrong credentials for user: ' . $gaSql['user']);
    }
}

希望這可以幫助 ;-)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM