php - 尽管连接到数据库,mysqli 查询响应仍然为空

标签 php mysql mysqli google-cloud-datastore

我使用mysqli连接远程mysql数据库。我没有收到任何连接错误,但是当我键入测试查询时,控制台中的 $response 变量仅显示五行空格。这是我的连接代码:

        ini_set ('error_reporting', E_ALL);
        ini_set ('display_errors', '1');
        error_reporting (E_ALL|E_STRICT);

        $connection = mysqli_init();
        mysqli_options ($connection, MYSQLI_CLIENT_SSL_VERIFY_SERVER_CERT, true);

        mysqli_ssl_set($connection,'/usr/local/certs/client-key.pem',
       '/usr/local/certs/client-cert.pem', '/usr/local/certs/server-ca.pem', NULL, NULL);

        $link = mysqli_real_connect ($connection, $db['host'], 
       $db['user'],$db['password'], $db['dbName'], 3306, NULL,MYSQLI_CLIENT_SSL_DONT_VERIFY_SERVER_CERT);


        if (!$link)
        {   
            die ('Connect error (' . mysqli_connect_errno() . '): ' . mysqli_connect_error() . "\n");
        } 
        else 
        {   
            $this->output->writeln($link); // this returns '1'
            $response = $connection->query('SHOW TABLES;');
            $this->output->writeln($response); // here I get blank lines 
            // even if tables exist within database


            $connection->close();
        }

注意:由于 mysql 远程服务器使用谷歌云,由于 SSL 证书,我在连接时遇到了一些问题。所以我发现我需要放置 MYSQLI_CLIENT_SSL_DONT_VERIFY_SERVER_CERT 标志以避免出现问题。这可能是一个重要的问题。

最佳答案

在所有情况下执行查询都不会返回该查询的结果。 查询如果成功,只会返回一个句柄,用于获取该查询的结果。

因此,您需要添加某种 mysqli_fetch 来一次获取结果集的每一行。查看修改后的代码

在这种情况下,因为 SHOW TABLES 的结果有点不寻常,我使用了 fetch_array(MYSQLI_NUM) 来使处理结果更容易,但通常您更可能使用 fetch_assoc() fetch_object()

<?php
ini_set ('error_reporting', E_ALL);
ini_set ('display_errors', '1');
error_reporting (E_ALL|E_STRICT);

$connection = mysqli_init();
mysqli_options ($connection, MYSQLI_CLIENT_SSL_VERIFY_SERVER_CERT, true);

mysqli_ssl_set($connection,
                '/usr/local/certs/client-key.pem',
                '/usr/local/certs/client-cert.pem', 
                '/usr/local/certs/server-ca.pem', 
                NULL, NULL);

$link = mysqli_real_connect ($connection, $db['host'],
                             $db['user'],$db['password'], 
                             $db['dbName'], 3306, NULL,
                             MYSQLI_CLIENT_SSL_DONT_VERIFY_SERVER_CERT);

if (!$link) {
    $this->output->writeln('Connect error (' . 
                        mysqli_connect_errno() . '): ' . 
                        mysqli_connect_error() . "\n"
                    );
} else {   
    $this->output->writeln($link); // this returns '1'
    $response = $connection->query('SHOW TABLES;');

    while ( $row = $response->fetch_array(MYSQLI_NUM)) {
        $this->output->writeln($row[0]);
    }

    $connection->close();
}

关于php - 尽管连接到数据库,mysqli 查询响应仍然为空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47926545/

相关文章:

php - 调用非对象上的成员函数bind_param()

php - Database_Exception [2]:mysqli_connect():服务器向客户端发送了未知的字符集(255)。请向开发商报告

php - 无法将变量写入 SQL 数据库

php - 两个用户可以共享相同的浏览器和站点但具有不同的 session 吗

php - 使用mysql按年龄获取DOB的时间戳

php - 通过单击链接在 cookie 中设置语言设置

sql - MySQL连接语句

mysql - Sequelize cli 创建属于用户或员工的关联

php - PayPal PHP IPN 示例指的是哪些 POST 序列化问题?

php - 我正在 PHP 中访问 MySQL 表,但它没有执行 if 条件并直接显示表