summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xext/pdo_mysql/mysql_driver.c3
-rwxr-xr-xext/pdo_mysql/mysql_statement.c15
2 files changed, 13 insertions, 5 deletions
diff --git a/ext/pdo_mysql/mysql_driver.c b/ext/pdo_mysql/mysql_driver.c
index b57599c322..08b4429880 100755
--- a/ext/pdo_mysql/mysql_driver.c
+++ b/ext/pdo_mysql/mysql_driver.c
@@ -225,7 +225,8 @@ static long mysql_handle_doer(pdo_dbh_t *dbh, const char *sql, long sql_len TSRM
pdo_mysql_error(dbh);
return -1;
} else {
- return mysql_affected_rows(H->server);
+ my_ulonglong c= mysql_affected_rows(H->server);
+ return c != (my_ulonglong)-1 ? c:-1;
}
}
diff --git a/ext/pdo_mysql/mysql_statement.c b/ext/pdo_mysql/mysql_statement.c
index 0051313b71..6527496e75 100755
--- a/ext/pdo_mysql/mysql_statement.c
+++ b/ext/pdo_mysql/mysql_statement.c
@@ -155,9 +155,12 @@ static int pdo_mysql_stmt_execute(pdo_stmt_t *stmt TSRMLS_DC)
}
}
-
- stmt->row_count = mysql_stmt_affected_rows(S->stmt);
- return 1;
+ ;
+ if ((row_count= mysql_stmt_affected_rows(S->stmt)) != (my_ulonglong)-1) {
+ stmt->row_count = row_count;
+ return 1;
+ }
+ return 0;
}
#endif
/* ensure that we free any previous unfetched results */
@@ -222,7 +225,11 @@ static int pdo_mysql_stmt_next_rowset(pdo_stmt_t *stmt TSRMLS_DC)
/* No more results */
return 0;
} else {
- row_count = mysql_affected_rows(H->server);
+ if ((my_ulonglong)-1 == (row_count = mysql_affected_rows(H->server))) {
+ pdo_mysql_error_stmt(stmt);
+ return 0;
+ }
+
if (!H->buffered) {
S->result = mysql_use_result(H->server);
} else {