6

我试图PDO::MYSQL_ATTR_FOUND_ROWS在 PDO 中将属性设置为 true,但我似乎无法设置它。我正在使用 PHP 5.4.16 和 MySQL 5.5。PDO并且pdo_mysql都出现在我的phpinfo().

这是我尝试将其设置为true的方法。

public function __construct () {
    $dsn = 'mysql:host=' . DB_HOST . ';dbname=' . DB_NAME . ';charset=utf8';
    $this->_db = new PDO($dsn,DB_USER,DB_PASS);

    // The following setAttribute() returns FALSE.
    $this->_db->setAttribute(PDO::MYSQL_ATTR_FOUND_ROWS, TRUE); 
}

我试图寻找我能想到的所有可能的设置。我还缺少什么?

4

1 回答 1

18

这似乎PDO::MYSQL_ATTR_FOUND_ROWS一个mysql连接选项。因此,它也只能用作 PDO 连接选项。所以,这样设置

$opt  = array(
    PDO::MYSQL_ATTR_FOUND_ROWS   => TRUE,
    // you may wish to set other options as well
    PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
);
$this->_db = new PDO($dsn,DB_USER,DB_PASS,$opt);
于 2013-09-08T13:18:11.487 回答