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;
|
pdo_sqlite_db_handle *H;
|
||||||
sqlite3_stmt *stmt;
|
sqlite3_stmt *stmt;
|
||||||
unsigned pre_fetched:1;
|
unsigned pre_fetched:1;
|
||||||
|
unsigned done:1;
|
||||||
} pdo_sqlite_stmt;
|
} pdo_sqlite_stmt;
|
||||||
|
|
||||||
extern pdo_driver_t pdo_sqlite_driver;
|
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;
|
pdo_sqlite_db_handle *H = S->H;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
if (stmt->executed) {
|
||||||
|
sqlite3_reset(S->stmt);
|
||||||
|
}
|
||||||
|
|
||||||
|
S->done = 0;
|
||||||
i = sqlite3_step(S->stmt);
|
i = sqlite3_step(S->stmt);
|
||||||
switch (i) {
|
switch (i) {
|
||||||
case SQLITE_ROW:
|
case SQLITE_ROW:
|
||||||
|
@ -61,6 +66,7 @@ static int pdo_sqlite_stmt_execute(pdo_stmt_t *stmt TSRMLS_DC)
|
||||||
case SQLITE_DONE:
|
case SQLITE_DONE:
|
||||||
stmt->column_count = sqlite3_data_count(S->stmt);
|
stmt->column_count = sqlite3_data_count(S->stmt);
|
||||||
sqlite3_reset(S->stmt);
|
sqlite3_reset(S->stmt);
|
||||||
|
S->done = 1;
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
case SQLITE_ERROR:
|
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) {
|
switch (event_type) {
|
||||||
case PDO_PARAM_EVT_EXEC_PRE:
|
case PDO_PARAM_EVT_EXEC_PRE:
|
||||||
|
if (stmt->executed && !S->done) {
|
||||||
|
sqlite3_reset(S->stmt);
|
||||||
|
S->done = 1;
|
||||||
|
}
|
||||||
|
|
||||||
if (param->is_param) {
|
if (param->is_param) {
|
||||||
switch (param->param_type) {
|
switch (param->param_type) {
|
||||||
case PDO_PARAM_LOB:
|
case PDO_PARAM_LOB:
|
||||||
|
@ -123,16 +134,22 @@ static int pdo_sqlite_stmt_fetch(pdo_stmt_t *stmt TSRMLS_DC)
|
||||||
S->pre_fetched = 0;
|
S->pre_fetched = 0;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
if (S->done) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
i = sqlite3_step(S->stmt);
|
i = sqlite3_step(S->stmt);
|
||||||
switch (i) {
|
switch (i) {
|
||||||
case SQLITE_ROW:
|
case SQLITE_ROW:
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
case SQLITE_DONE:
|
case SQLITE_DONE:
|
||||||
|
S->done = 1;
|
||||||
sqlite3_reset(S->stmt);
|
sqlite3_reset(S->stmt);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
printf("cluck done=%d pre_fetched=%d executed=%d\n", S->done, S->pre_fetched, stmt->executed);
|
||||||
pdo_sqlite_error_stmt(stmt);
|
pdo_sqlite_error_stmt(stmt);
|
||||||
return 0;
|
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 = {
|
struct pdo_stmt_methods sqlite_stmt_methods = {
|
||||||
pdo_sqlite_stmt_dtor,
|
pdo_sqlite_stmt_dtor,
|
||||||
pdo_sqlite_stmt_execute,
|
pdo_sqlite_stmt_execute,
|
||||||
pdo_sqlite_stmt_fetch,
|
pdo_sqlite_stmt_fetch,
|
||||||
pdo_sqlite_stmt_describe,
|
pdo_sqlite_stmt_describe,
|
||||||
pdo_sqlite_stmt_get_col,
|
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