PDO设置PDO :: MYSQL_ATTR_FOUND_ROWS失败 [英] PDO Setting PDO::MYSQL_ATTR_FOUND_ROWS fails

查看:96
本文介绍了PDO设置PDO :: MYSQL_ATTR_FOUND_ROWS失败的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

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

I'm trying to set PDO::MYSQL_ATTR_FOUND_ROWS attribute to true in PDO, but I cannot seem to set it. I am using PHP 5.4.16 and MySQL 5.5.PDO and pdo_mysql both appear in my phpinfo().

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

Here is how I try to set it to 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); 
}

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

I tried to look for every possible settings I can think of. What am I still missing?

推荐答案

似乎 PDO::MYSQL_ATTR_FOUND_ROWS mysql连接选项.因此,它也仅用作PDO连接选项.因此,以这种方式进行设置

It seems that PDO::MYSQL_ATTR_FOUND_ROWS is a mysql connection option. Thus, it works only as PDO connection option as well. So, set it up this way

$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);

这篇关于PDO设置PDO :: MYSQL_ATTR_FOUND_ROWS失败的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆