mirror of
https://github.com/php/php-src.git
synced 2024-10-21 00:12:34 +00:00
98 lines
3.4 KiB
Plaintext
98 lines
3.4 KiB
Plaintext
|
--TEST--
|
||
|
MySQL PDOStatement->fetch(), PDO::FETCH_SERIALIZE
|
||
|
--SKIPIF--
|
||
|
<?php
|
||
|
require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'skipif.inc');
|
||
|
require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'mysql_pdo_test.inc');
|
||
|
MySQLPDOTest::skip();
|
||
|
if (version_compare(PHP_VERSION, '5.1.0', '<'))
|
||
|
die("skip Needs 5.1.0 and Interface Serializable");
|
||
|
?>
|
||
|
--FILE--
|
||
|
<?php
|
||
|
require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'mysql_pdo_test.inc');
|
||
|
$db = MySQLPDOTest::factory();
|
||
|
|
||
|
try {
|
||
|
|
||
|
class myclass implements Serializable {
|
||
|
|
||
|
public function __construct($caller = null) {
|
||
|
printf("%s(%s) - note that it must not be called when unserializing\n", __METHOD__, var_export($caller, true));
|
||
|
}
|
||
|
|
||
|
public function __set($prop, $value) {
|
||
|
printf("%s(%s, %s)\n", __METHOD__, var_export($prop, true), var_export($value, true));
|
||
|
$this->{$prop} = $value;
|
||
|
}
|
||
|
|
||
|
public function serialize() {
|
||
|
printf("%s()\n", __METHOD__);
|
||
|
return 'Value from serialize()';
|
||
|
}
|
||
|
|
||
|
public function unserialize($data) {
|
||
|
printf("%s(%s)\n", __METHOD__, var_export($data, true));
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
printf("Lets see what the Serializeable interface makes our object behave like...\n");
|
||
|
$obj = new myclass('Called by script');
|
||
|
$tmp = unserialize(serialize($obj));
|
||
|
var_dump($tmp);
|
||
|
|
||
|
printf("\nAnd now magic PDO using fetchAll(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE)...\n");
|
||
|
$db->exec('DROP TABLE IF EXISTS test');
|
||
|
$db->exec(sprintf('CREATE TABLE test(myobj BLOB) ENGINE=%s', MySQLPDOTest::getTableEngine()));
|
||
|
$db->exec('INSERT INTO test(myobj) VALUES ("Data fetched from DB to be given to unserialize()")');
|
||
|
|
||
|
$stmt = $db->prepare('SELECT myobj FROM test');
|
||
|
$stmt->execute();
|
||
|
$rows = $stmt->fetchAll(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE, 'myclass', array('Called by PDO'));
|
||
|
var_dump($rows[0]);
|
||
|
|
||
|
$stmt->execute();
|
||
|
$rows = $stmt->fetchAll(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE, 'myclass');
|
||
|
var_dump($rows[0]);
|
||
|
|
||
|
printf("\nAnd now PDO using setFetchMode(PDO::FETCH:CLASS|PDO::FETCH_SERIALIZE) + fetch()...\n");
|
||
|
$stmt = $db->prepare('SELECT myobj FROM test');
|
||
|
$stmt->setFetchMode(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE, 'myclass', array('Called by PDO'));
|
||
|
$stmt->execute();
|
||
|
var_dump($stmt->fetch());
|
||
|
|
||
|
} catch (PDOException $e) {
|
||
|
printf("[001] %s [%s] %s\n",
|
||
|
$e->getMessage(), $db->errorCode(), implode(' ', $db->errorInfo()));
|
||
|
}
|
||
|
|
||
|
$db->exec('DROP TABLE IF EXISTS test');
|
||
|
print "done!\n";
|
||
|
?>
|
||
|
--EXPECTF--
|
||
|
Lets see what the Serializeable interface makes our object behave like...
|
||
|
myclass::__construct('Called by script') - note that it must not be called when unserializing
|
||
|
myclass::serialize()
|
||
|
myclass::unserialize('Value from serialize()')
|
||
|
object(myclass)#%d (0) {
|
||
|
}
|
||
|
|
||
|
And now magic PDO using fetchAll(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE)...
|
||
|
myclass::unserialize('Data fetched from DB to be given to unserialize()')
|
||
|
myclass::__construct('Called by PDO') - note that it must not be called when unserializing
|
||
|
object(myclass)#%d (0) {
|
||
|
}
|
||
|
myclass::unserialize('Data fetched from DB to be given to unserialize()')
|
||
|
myclass::__construct(NULL) - note that it must not be called when unserializing
|
||
|
object(myclass)#%d (0) {
|
||
|
}
|
||
|
|
||
|
And now PDO using setFetchMode(PDO::FETCH:CLASS|PDO::FETCH_SERIALIZE) + fetch()...
|
||
|
myclass::__set('myobj', 'Data fetched from DB to be given to unserialize()')
|
||
|
myclass::__construct('Called by PDO') - note that it must not be called when unserializing
|
||
|
object(myclass)#%d (1) {
|
||
|
["myobj"]=>
|
||
|
string(49) "Data fetched from DB to be given to unserialize()"
|
||
|
}
|
||
|
done!
|