]> granicus.if.org Git - php/commitdiff
Fixed bug #51213 (pdo_mssql is trimming value of the money column).
authorIlia Alshanetsky <iliaa@php.net>
Mon, 8 Mar 2010 12:39:44 +0000 (12:39 +0000)
committerIlia Alshanetsky <iliaa@php.net>
Mon, 8 Mar 2010 12:39:44 +0000 (12:39 +0000)
ext/pdo_dblib/dblib_stmt.c

index 2a447c036facaee0c4b23b59f7ec91cd975904cd..d3e87555a0ae88b6530967c0b2368b59dddff5ff 100644 (file)
@@ -166,7 +166,14 @@ static int pdo_dblib_stmt_execute(pdo_stmt_t *stmt TSRMLS_DC)
                                                memcpy(val->data, dbdata(H->link, i+1), val->len);
                                                val->data[val->len] = '\0';
                                                break;
-
+                                       case SQLMONEY:
+                                       case SQLMONEY4:
+                                       case SQLMONEYN: {
+                                               DBFLT8 money_value;
+                                               dbconvert(NULL, S->cols[i].coltype, dbdata(H->link, i+1), dbdatlen(H->link, i+1), SQLFLT8, (LPBYTE)&money_value, val->len);
+                                               val->len = spprintf(val->data, 0, "%.4f", money_value);
+                                               }
+                                               break;
                                        default:
                                                if (dbwillconvert(S->cols[i].coltype, SQLCHAR)) {
                                                        val->len = 32 + (2 * dbdatlen(H->link, i+1));