summaryrefslogtreecommitdiff
path: root/ext/odbc/php_odbc.c
diff options
context:
space:
mode:
authorChristoph M. Becker <cmb@php.net>2015-07-03 00:25:03 +0200
committerChristoph M. Becker <cmb@php.net>2015-07-03 00:25:03 +0200
commitcaa539b4814f715cb1a53961c85b56c8eb957f39 (patch)
tree1d467d2348ca564732e7d7e4e498354170acd6a0 /ext/odbc/php_odbc.c
parent57881e878db7bb2c19833aa44c097ea3af2fbb2e (diff)
parent616661e0f8368365f50fe9aea7606782aa7552dc (diff)
downloadphp-git-caa539b4814f715cb1a53961c85b56c8eb957f39.tar.gz
Merge branch 'PHP-5.6'
* PHP-5.6: updated NEWS Fix #69975: PHP segfaults when accessing nvarchar(max) defined columns
Diffstat (limited to 'ext/odbc/php_odbc.c')
-rw-r--r--ext/odbc/php_odbc.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/ext/odbc/php_odbc.c b/ext/odbc/php_odbc.c
index b5f3b97845..3451140fc3 100644
--- a/ext/odbc/php_odbc.c
+++ b/ext/odbc/php_odbc.c
@@ -1014,6 +1014,13 @@ int odbc_bindcols(odbc_result *result)
NULL, 0, NULL, &displaysize);
}
#endif
+ /* Workaround for drivers that report NVARCHAR(MAX) columns as SQL_WVARCHAR with size 0 (bug #69975) */
+ if (result->values[i].coltype == SQL_WVARCHAR && displaysize == 0) {
+ result->values[i].coltype = SQL_WLONGVARCHAR;
+ result->values[i].value = NULL;
+ break;
+ }
+
/* Workaround for Oracle ODBC Driver bug (#50162) when fetching TIMESTAMP column */
if (result->values[i].coltype == SQL_TIMESTAMP) {
displaysize += 3;