1

在任何人判断之前......我已经检查了其他有类似问题但仍然无法解决我的问题的帖子。

php mysqli 只返回一行

仅使用 MySQLi 获取一行

我还检查并阅读了 PHP 手册,没有运气使用不同的方法来提取数据。我的意思是我确实提取了一个表,该表甚至具有正确的行数。但是,所有行都具有相同的信息:第一行,即表示标题的行,即:名字、电话、地址等。

下面的代码显示了我是如何做的。我重申,mysqli 连接确实在提取包含数据的表,并且具有正确的行数。但我没有得到正确的信息。

public function queryexec()
{   
  if(isset($this->query))
  {
    //execute prepared query and store in result variable.
    $this->result = $this->connection->query($this->query);
    echo 'Table Row Count: '. $this->result->num_rows;

        echo '<br/>';

        //fetch_array gives me table but only headers but correct amount of rows.
        //Fetch_object doesnt work throws me error: 
        //Fatal error: Cannot use object of type stdClass as array   
        while($row = $this->result->fetch_array()){

             printf ("%s (%s)\n", $row[0], $row[2][1]);
            //echo 'Table Data: '. $newdata["LastName"];
           //echo '<br/>';
        }

        return true;
  }
  return false;
}
4

1 回答 1

2

您正在调用 fetch_object() 但随后您正在访问行元素,就好像它是一个序数数组一样。

您应该像访问对象的字段一样访问列,$row->LastName或者更改获取行的方式以使用$this->result->fetch_array()


我刚刚使用 PHP 5.3.26 和 MySQL 5.6.13 测试了您的代码。我没有收到任何错误,并且我得到了所有三行的不同数据:

mysql> show create table test.foo\G

CREATE TABLE `foo` (
  `id` int(11) NOT NULL,
  `z` int(11) DEFAULT NULL,
  `LastName` text,
  `t` text,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1

mysql> insert into foo (id, lastname) values 
(1, 'Granger'), (2, 'Potter'), (3, 'Weasley');

$ php 19236839.php
Table Row Count: 3<br/>
1 (r)
2 (o)
3 (e)

请注意,$row[2][1]返回单个字符,即字符串中的第二个字符。

于 2013-10-08T00:25:03.023 回答