0

mysqli::fetch_object (すべてPHP5 )を介して MySQL データベースから行をオブジェクトとしてフェッチすると、 var_dumpで次のようになります。

class stdClass#5 (5) {
  public $id =>
  string(2) "23"
  public $started =>
  NULL
  public $finished =>
  NULL
  public $mode =>
  string(3) "XML"
  public $mail =>
  string(0) ""
}

これを行うには:

    public function __construct($export) {
        var_dump($export);
        if (!($export instanceof stdClass)) {
//throw new exception ...
}

またはこれ

public function __construct(stdClass $export) {
        var_dump($export);
//...

またはis_object($export) - これは失敗します

私は実際に例外を取得します:

Fatal error: Uncaught exception 'Exception'
with message '$export is not an object'

また

Argument 1 passed to ConverterXML::__construct()
must be an instance of stdClass, none given
  1. どうして
    • またはさらに良い -
  2. $export が mysqli fetch_object の匿名クラスであることを確認するにはどうすればよいですか?
4

1 に答える 1

0

次のように正しく実行していれば、問題はないはずです。

$result = $mysqli->query($query);
while ($obj = $result->fetch_object()) {
    var_dump( $obj );
    var_dump( $obj instanceof stdClass );
    var_dump( is_object( $obj ) );
}

または、stdClass とは異なるオブジェクトのインスタンスが必要な場合:

class Employee {
    public function __construct( $id ) {
        $this->id = $id;
    }
}
$i = 0;
while ( $obj = $result->fetch_object( "Employee", array( $i ) ) ) {
    var_dump( $obj );
    $i++;
}
于 2013-05-17T12:33:34.433 に答える