mirror of
https://github.com/php/php-src.git
synced 2025-08-16 05:58:45 +02:00
meta data for sqlite3.
Fix repeated executes when the entire rowset has not been consumed.
This commit is contained in:
parent
eb0cd48d60
commit
486b426947
2 changed files with 71 additions and 1 deletions
|
@ -39,6 +39,7 @@ typedef struct {
|
|||
pdo_sqlite_db_handle *H;
|
||||
sqlite3_stmt *stmt;
|
||||
unsigned pre_fetched:1;
|
||||
unsigned done:1;
|
||||
} pdo_sqlite_stmt;
|
||||
|
||||
extern pdo_driver_t pdo_sqlite_driver;
|
||||
|
|
|
@ -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
|
||||
};
|
||||
|
||||
/*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue