diff options
author | Wez Furlong <wez@php.net> | 2004-09-26 20:46:35 +0000 |
---|---|---|
committer | Wez Furlong <wez@php.net> | 2004-09-26 20:46:35 +0000 |
commit | 486b4269475509161fd52877df03b9a725652e6c (patch) | |
tree | 67b32b2c95cdeaac6434c20df54bc895cc5f0d8f /ext/pdo_sqlite/sqlite_statement.c | |
parent | eb0cd48d6012d43231ec3d38a79dcf941e180002 (diff) | |
download | php-git-486b4269475509161fd52877df03b9a725652e6c.tar.gz |
meta data for sqlite3.
Fix repeated executes when the entire rowset has not been consumed.
Diffstat (limited to 'ext/pdo_sqlite/sqlite_statement.c')
-rw-r--r-- | ext/pdo_sqlite/sqlite_statement.c | 71 |
1 files changed, 70 insertions, 1 deletions
diff --git a/ext/pdo_sqlite/sqlite_statement.c b/ext/pdo_sqlite/sqlite_statement.c index c68106494f..431563df10 100644 --- a/ext/pdo_sqlite/sqlite_statement.c +++ b/ext/pdo_sqlite/sqlite_statement.c @@ -51,6 +51,11 @@ static int pdo_sqlite_stmt_execute(pdo_stmt_t *stmt TSRMLS_DC) pdo_sqlite_db_handle *H = S->H; int i; + if (stmt->executed) { + sqlite3_reset(S->stmt); + } + + S->done = 0; i = sqlite3_step(S->stmt); switch (i) { case SQLITE_ROW: @@ -61,6 +66,7 @@ static int pdo_sqlite_stmt_execute(pdo_stmt_t *stmt TSRMLS_DC) case SQLITE_DONE: stmt->column_count = sqlite3_data_count(S->stmt); sqlite3_reset(S->stmt); + S->done = 1; return 1; case SQLITE_ERROR: @@ -82,6 +88,11 @@ static int pdo_sqlite_stmt_param_hook(pdo_stmt_t *stmt, struct pdo_bound_param_d switch (event_type) { case PDO_PARAM_EVT_EXEC_PRE: + if (stmt->executed && !S->done) { + sqlite3_reset(S->stmt); + S->done = 1; + } + if (param->is_param) { switch (param->param_type) { case PDO_PARAM_LOB: @@ -123,16 +134,22 @@ static int pdo_sqlite_stmt_fetch(pdo_stmt_t *stmt TSRMLS_DC) S->pre_fetched = 0; return 1; } + if (S->done) { + return 0; + } + i = sqlite3_step(S->stmt); switch (i) { case SQLITE_ROW: return 1; case SQLITE_DONE: + S->done = 1; sqlite3_reset(S->stmt); return 0; default: + printf("cluck done=%d pre_fetched=%d executed=%d\n", S->done, S->pre_fetched, stmt->executed); pdo_sqlite_error_stmt(stmt); return 0; } @@ -198,13 +215,65 @@ static int pdo_sqlite_stmt_get_col(pdo_stmt_t *stmt, int colno, char **ptr, unsi } } +static int pdo_sqlite_stmt_col_meta(pdo_stmt_t *stmt, long colno, zval *return_value TSRMLS_DC) +{ + pdo_sqlite_stmt *S = (pdo_sqlite_stmt*)stmt->driver_data; + char *str; + zval *flags; + + if (!S->stmt) { + return FAILURE; + } + if(colno >= sqlite3_data_count(S->stmt)) { + /* error invalid column */ + pdo_sqlite_error_stmt(stmt); + return FAILURE; + } + + array_init(return_value); + MAKE_STD_ZVAL(flags); + array_init(flags); + + switch (sqlite3_column_type(S->stmt, colno)) { + case SQLITE_NULL: + add_assoc_string(return_value, "native_type", "null", 1); + break; + + case SQLITE_FLOAT: + add_assoc_string(return_value, "native_type", "double", 1); + break; + + case SQLITE_BLOB: + add_next_index_string(flags, "blob", 1); + case SQLITE_TEXT: + add_assoc_string(return_value, "native_type", "string", 1); + break; + + case SQLITE_INTEGER: + add_assoc_string(return_value, "native_type", "integer", 1); + break; + } + + str = (char*)sqlite3_column_decltype(S->stmt, colno); + if (str) { + add_assoc_string(return_value, "sqlite:decl_type", str, 1); + } + + add_assoc_zval(return_value, "flags", flags); + + return SUCCESS; +} + struct pdo_stmt_methods sqlite_stmt_methods = { pdo_sqlite_stmt_dtor, pdo_sqlite_stmt_execute, pdo_sqlite_stmt_fetch, pdo_sqlite_stmt_describe, pdo_sqlite_stmt_get_col, - pdo_sqlite_stmt_param_hook + pdo_sqlite_stmt_param_hook, + NULL, /* set_attr */ + NULL, /* get_attr */ + pdo_sqlite_stmt_col_meta }; /* |