summaryrefslogtreecommitdiff
path: root/ext/mysqli/tests/bug_mysql_49406.phpt
blob: 74ea471702a2a49c1c0503fbe0a32e41f67f4a3a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
--TEST--
MySQL Bug #49406 (Binding params doesn't work when selecting a date inside a CASE-WHEN, http://bugs.mysql.com/bug.php?id=49406)
--SKIPIF--
<?php
require_once('skipif.inc');
require_once('skipifconnectfailure.inc');
?>
--FILE--
<?php
	require_once("connect.inc");

	if (!($link = my_mysqli_connect($host, $user, $passwd, $db, $port, $socket)))
		printf("[001] Cannot connect to the server using host=%s, user=%s, passwd=***, dbname=%s, port=%s, socket=%s\n",
			$host, $user, $db, $port, $socket);

	$query = "SELECT CASE  WHEN 0 THEN CAST('2009-12-03' AS DATE)  ELSE CAST('2009-12-03' AS DATE) END";

	if (!$res = $link->query($query))
		printf("[002] [%d] %s\n", $link->errno, $link->error);

	if (!$row = $res->fetch_row())
		printf("[003] No result, [%d] %s\n", $link->errno, $link->error);

	$res->free();

	if ($row[0] != '2009-12-03') {
		printf("[004] Expecting '2009-12-03' got '%s'\n", $row[0]);
	}

	if (!$stmt = $link->prepare($query))
		printf("[005] [%d] %s\n", $link->errno, $link->error);

	if (!$stmt->execute() || !$stmt->store_result())
		printf("[006] [%d] %s\n", $stmt->errno, $stmt->error);


	$datatypes = array(
		MYSQLI_TYPE_TINY => "TINY",
		MYSQLI_TYPE_SHORT => "SHORT",
		MYSQLI_TYPE_LONG => "LONG",
		MYSQLI_TYPE_FLOAT => "FLOAT",
		MYSQLI_TYPE_DOUBLE => "DOUBLE",
		MYSQLI_TYPE_TIMESTAMP => "TIMESTAMP",
		MYSQLI_TYPE_LONGLONG => "LONGLONG",
		MYSQLI_TYPE_INT24 => "INT24",
		MYSQLI_TYPE_DATE => "DATE",
		MYSQLI_TYPE_TIME => "TIME",
		MYSQLI_TYPE_DATETIME => "DATETIME",
		MYSQLI_TYPE_YEAR => "YEAR",
		MYSQLI_TYPE_ENUM => "ENUM",
		MYSQLI_TYPE_SET	=> "SET",
		MYSQLI_TYPE_TINY_BLOB => "TINYBLOB",
		MYSQLI_TYPE_MEDIUM_BLOB => "MEDIUMBLOB",
		MYSQLI_TYPE_LONG_BLOB => "LONGBLOB",
		MYSQLI_TYPE_BLOB => "BLOB",
		MYSQLI_TYPE_VAR_STRING => "VAR_STRING",
		MYSQLI_TYPE_STRING => "STRING",
		MYSQLI_TYPE_NULL => "NULL",
		MYSQLI_TYPE_NEWDATE => "NEWDATE",
		MYSQLI_TYPE_INTERVAL => "INTERVAL",
		MYSQLI_TYPE_GEOMETRY => "GEOMETRY",
	);

	$meta_res = $stmt->result_metadata();
	for ($field_idx = 0; $field_idx < $meta_res->field_count; $field_idx++) {
		$field = $meta_res->fetch_field();
		printf("Field        : %d\n", $field_idx);
		printf("Name         : %s\n", $field->name);
		printf("Orgname      : %s\n", $field->orgname);
		printf("Table        : %s\n", $field->table);
		printf("Orgtable     : %s\n", $field->orgtable);
		printf("Maxlength    : %d\n", $field->max_length);
		printf("Length       : %d\n", $field->length);
		printf("Charsetnr    : %d\n", $field->charsetnr);
		printf("Flags        : %d\n", $field->flags);
		printf("Type         : %d (%s)\n", $field->type, (isset($datatypes[$field->type])) ? $datatypes[$field->type] : 'unknown');
		printf("Decimals     : %d\n", $field->decimals);
	}

	$row_stmt = null;
	if (!$stmt->bind_result($row_stmt) || !$stmt->fetch())
		printf("[007] [%d] %s\n", $stmt->errno, $stmt->error);

	if ($row[0] != $row_stmt) {
		printf("[008] PS and non-PS results differ, dumping data\n");
		var_dump($row[0]);
		var_dump($row_stmt);
	}

	$stmt->close();
	$link->close();

	echo "done";
?>
--EXPECTF--
Field        : %s
Name         : %s
Orgname      :%s
Table        :%s
Orgtable     :%s
Maxlength    : %d
Length       : %d
Charsetnr    : %d
Flags        : %d
Type         : %d (%s)
Decimals     : %d
done