File:
[ELWIX - Embedded LightWeight unIX -] /
embedaddon /
php /
ext /
mysqli /
tests /
mysqli_stmt_get_result_metadata_fetch_field.phpt
Revision
1.1.1.1 (vendor branch):
download - view:
text,
annotated -
select for diffs -
revision graph
Tue Feb 21 23:47:58 2012 UTC (12 years, 5 months ago) by
misho
Branches:
php,
MAIN
CVS tags:
v5_4_3elwix,
v5_4_29p0,
v5_4_29,
v5_4_20p0,
v5_4_20,
v5_4_17p0,
v5_4_17,
v5_3_10,
HEAD
php
--TEST--
mysqli_stmt_get_result() - meta data, field info
--SKIPIF--
<?php
require_once('skipif.inc');
require_once('skipifemb.inc');
require_once('skipifconnectfailure.inc');
if (!function_exists('mysqli_stmt_get_result'))
die('skip mysqli_stmt_get_result not available');
?>
--FILE--
<?php
require('table.inc');
$charsets = my_get_charsets($link);
if (!($stmt = mysqli_stmt_init($link)) ||
!mysqli_stmt_prepare($stmt, "SELECT id, label, id + 1 as _id, concat(label, '_') ___label FROM test ORDER BY id ASC LIMIT 3") ||
!mysqli_stmt_execute($stmt))
printf("[001] [%d] %s\n", mysqli_stmt_errno($stmt), mysqli_stmt_error($stmt));
if (!is_object($res = mysqli_stmt_get_result($stmt)) || 'mysqli_result' != get_class($res)) {
printf("[002] Expecting object/mysqli_result got %s/%s, [%d] %s\n",
gettype($res), $res, mysqli_stmt_errno($stmt), mysqli_stmt_error($stmt));
}
if (!is_object($res_meta = mysqli_stmt_result_metadata($stmt)) ||
'mysqli_result' != get_class($res_meta)) {
printf("[003] Expecting object/mysqli_result got %s/%s, [%d] %s\n",
gettype($res), $res, mysqli_stmt_errno($stmt), mysqli_stmt_error($stmt));
}
$i = 0;
while ($field = $res->fetch_field()) {
var_dump($field);
$i++;
if (2 == $i) {
/*
Label column, result set charset.
All of the following columns are "too hot" - too server dependent
*/
if ($field->charsetnr != $charsets['results']['nr']) {
printf("[004] Expecting charset %s/%d got %d\n",
$charsets['results']['charset'],
$charsets['results']['nr'], $field->charsetnr);
}
if ($field->length != (1 * $charsets['results']['maxlen'])) {
printf("[005] Expecting length %d got %d\n",
$charsets['results']['maxlen'],
$field->max_length);
}
}
}
mysqli_stmt_close($stmt);
mysqli_close($link);
print "done!";
?>
--CLEAN--
<?php
require_once("clean_table.inc");
?>
--EXPECTF--
object(stdClass)#%d (13) {
[%u|b%"name"]=>
%unicode|string%(2) "id"
[%u|b%"orgname"]=>
%unicode|string%(2) "id"
[%u|b%"table"]=>
%unicode|string%(4) "test"
[%u|b%"orgtable"]=>
%unicode|string%(4) "test"
[%u|b%"def"]=>
%unicode|string%(0) ""
[%u|b%"db"]=>
%unicode|string%(%d) "%s"
[%u|b%"catalog"]=>
%unicode|string%(%d) "%s"
[%u|b%"max_length"]=>
int(0)
[%u|b%"length"]=>
int(11)
[%u|b%"charsetnr"]=>
int(63)
[%u|b%"flags"]=>
int(49155)
[%u|b%"type"]=>
int(3)
[%u|b%"decimals"]=>
int(0)
}
object(stdClass)#%d (13) {
[%u|b%"name"]=>
%unicode|string%(5) "label"
[%u|b%"orgname"]=>
%unicode|string%(5) "label"
[%u|b%"table"]=>
%unicode|string%(4) "test"
[%u|b%"orgtable"]=>
%unicode|string%(4) "test"
[%u|b%"def"]=>
%unicode|string%(0) ""
[%u|b%"db"]=>
%unicode|string%(%d) "%s"
[%u|b%"catalog"]=>
%unicode|string%(%d) "%s"
[%u|b%"max_length"]=>
int(%d)
[%u|b%"length"]=>
int(%d)
[%u|b%"charsetnr"]=>
int(%d)
[%u|b%"flags"]=>
int(0)
[%u|b%"type"]=>
int(254)
[%u|b%"decimals"]=>
int(0)
}
object(stdClass)#%d (13) {
[%u|b%"name"]=>
%unicode|string%(3) "_id"
[%u|b%"orgname"]=>
%unicode|string%(0) ""
[%u|b%"table"]=>
%unicode|string%(0) ""
[%u|b%"orgtable"]=>
%unicode|string%(0) ""
[%u|b%"def"]=>
%unicode|string%(0) ""
[%u|b%"db"]=>
%unicode|string%(0) ""
[%u|b%"catalog"]=>
%unicode|string%(%d) "%s"
[%u|b%"max_length"]=>
int(0)
[%u|b%"length"]=>
int(%d)
[%u|b%"charsetnr"]=>
int(63)
[%u|b%"flags"]=>
int(32897)
[%u|b%"type"]=>
int(8)
[%u|b%"decimals"]=>
int(0)
}
object(stdClass)#%d (13) {
[%u|b%"name"]=>
%unicode|string%(8) "___label"
[%u|b%"orgname"]=>
%unicode|string%(0) ""
[%u|b%"table"]=>
%unicode|string%(0) ""
[%u|b%"orgtable"]=>
%unicode|string%(0) ""
[%u|b%"def"]=>
%unicode|string%(0) ""
[%u|b%"db"]=>
%unicode|string%(0) ""
[%u|b%"catalog"]=>
%unicode|string%(%d) "%s"
[%u|b%"max_length"]=>
int(%d)
[%u|b%"length"]=>
int(%d)
[%u|b%"charsetnr"]=>
int(%d)
[%u|b%"flags"]=>
int(0)
[%u|b%"type"]=>
int(253)
[%u|b%"decimals"]=>
int(31)
}
done!
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>