Skip to content

Commit

Permalink
Merge pull request #55 from jopoly/RELEASE_v2.3.0
Browse files Browse the repository at this point in the history
RELEASE v2.3.0
  • Loading branch information
t-kataym authored Jan 17, 2023
2 parents 31133bd + 6a9b5ac commit 3a495b7
Show file tree
Hide file tree
Showing 195 changed files with 586 additions and 486 deletions.
4 changes: 2 additions & 2 deletions META.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,15 @@
"name": "sqlite_fdw",
"abstract": "Foreign Data Wrapper for SQLite databases",
"description": "PostgreSQL extension which implements a Foreign Data Wrapper (FDW) for SQLite databases.",
"version": "2.2.0",
"version": "2.3.0",
"maintainer": "pgspider",
"license": "postgresql",
"provides": {
"sqlite_fdw": {
"abstract": "Foreign Data Wrapper for SQLite databases",
"file": "sqlite_fdw.c",
"docfile": "README.md",
"version": "2.2.0"
"version": "2.3.0"
}
},
"prereqs": {
Expand Down
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,7 @@ SELECT * FROM t1;
- SQLite FDW only supports ARRAY const, for example, ANY (ARRAY[1, 2, 3]) or ANY ('{1, 2 ,3}'). SQlite FDW does not support ARRAY expression, for example, ANY (ARRAY[c1, 1, c1+0]). For ANY(ARRAY) clause, SQLite FDW deparses it using IN operator.
- For sum function of SQLite, output of sum(bigint) is integer value. If input values are big, the overflow error may occurs on SQLite because it overflow within the range of signed 64bit. For PostgreSQL, it can calculate as over the precision of bigint, so overflow does not occur.
- SQLite promises to preserve the 15 most significant digits of a floating point value. The big value which exceed 15 most significant digits may become different value after inserted.
- SQLite does not support Numeric type as PostgreSQL. Therefore, it does not allow to store numbers with too high precision and scale. Error out of range occurs.
## Contributing
Opening issues and pull requests on GitHub are welcome.

Expand Down
82 changes: 68 additions & 14 deletions connection.c
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ PG_FUNCTION_INFO_V1(sqlite_fdw_disconnect);
PG_FUNCTION_INFO_V1(sqlite_fdw_disconnect_all);

static void sqlite_make_new_connection(ConnCacheEntry *entry, ForeignServer *server);
void sqlite_do_sql_command(sqlite3 * conn, const char *sql, int level);
void sqlite_do_sql_command(sqlite3 * conn, const char *sql, int level, List **busy_connection);
static void sqlite_begin_remote_xact(ConnCacheEntry *entry);
static void sqlitefdw_xact_callback(XactEvent event, void *arg);
static void sqlitefdw_reset_xact_state(ConnCacheEntry *entry, bool toplevel);
Expand All @@ -75,13 +75,20 @@ static void sqlitefdw_subxact_callback(SubXactEvent event,
SubTransactionId parentSubid,
void *arg);
static void sqlitefdw_inval_callback(Datum arg, int cacheid, uint32 hashvalue);
static void sqlitefdw_abort_cleanup(ConnCacheEntry *entry, bool toplevel);
static void sqlitefdw_abort_cleanup(ConnCacheEntry *entry, bool toplevel, List **busy_connection);
#if PG_VERSION_NUM >= 140000
static bool sqlite_disconnect_cached_connections(Oid serverid);
#endif
static void sqlite_finalize_list_stmt(List **list);
static List *sqlite_append_stmt_to_list(List *list, sqlite3_stmt * stmt);

typedef struct BusyHandlerArg
{
sqlite3 *conn;
const char *sql;
int level;
} BusyHandlerArg;

/*
* sqlite_get_connection:
* Get a connection which can be used to execute queries on
Expand Down Expand Up @@ -264,18 +271,33 @@ sqlite_cleanup_connection(void)
}
}


/*
* Convenience subroutine to issue a non-data-returning SQL command to remote
*/
void
sqlite_do_sql_command(sqlite3 * conn, const char *sql, int level)
sqlite_do_sql_command(sqlite3 * conn, const char *sql, int level, List **busy_connection)
{
char *err = NULL;
int rc;

elog(DEBUG3, "sqlite_fdw do_sql_command %s", sql);

if (sqlite3_exec(conn, sql, NULL, NULL, &err) != SQLITE_OK)
rc = sqlite3_exec(conn, sql, NULL, NULL, &err);

if (busy_connection && rc == SQLITE_BUSY)
{
/* Busy case will be handled later, not here */
BusyHandlerArg *arg = palloc0(sizeof(BusyHandlerArg));

arg->conn = conn;
arg->sql = sql;
arg->level = level;
*busy_connection = lappend(*busy_connection, arg);

return;
}

if (rc != SQLITE_OK)
{
char *perr = NULL;

Expand Down Expand Up @@ -319,7 +341,7 @@ sqlite_begin_remote_xact(ConnCacheEntry *entry)

sql = "BEGIN";

sqlite_do_sql_command(entry->conn, sql, ERROR);
sqlite_do_sql_command(entry->conn, sql, ERROR, NULL);
entry->xact_depth = 1;

}
Expand All @@ -334,7 +356,7 @@ sqlite_begin_remote_xact(ConnCacheEntry *entry)
char sql[64];

snprintf(sql, sizeof(sql), "SAVEPOINT s%d", entry->xact_depth + 1);
sqlite_do_sql_command(entry->conn, sql, ERROR);
sqlite_do_sql_command(entry->conn, sql, ERROR, NULL);
entry->xact_depth++;
}
}
Expand Down Expand Up @@ -377,6 +399,8 @@ sqlitefdw_xact_callback(XactEvent event, void *arg)
{
HASH_SEQ_STATUS scan;
ConnCacheEntry *entry;
ListCell *lc;
List *busy_connection = NIL;

/* Quick exit if no connections were touched in this transaction. */
if (!xact_got_connection)
Expand Down Expand Up @@ -408,7 +432,7 @@ sqlitefdw_xact_callback(XactEvent event, void *arg)

/* Commit all remote transactions during pre-commit */
if (!sqlite3_get_autocommit(entry->conn))
sqlite_do_sql_command(entry->conn, "COMMIT", ERROR);
sqlite_do_sql_command(entry->conn, "COMMIT", ERROR, &busy_connection);
/* Finalize all prepared statements */
sqlite_finalize_list_stmt(&entry->stmtList);
break;
Expand Down Expand Up @@ -436,7 +460,7 @@ sqlitefdw_xact_callback(XactEvent event, void *arg)
case XACT_EVENT_PARALLEL_ABORT:
case XACT_EVENT_ABORT:
{
sqlitefdw_abort_cleanup(entry, true);
sqlitefdw_abort_cleanup(entry, true, &busy_connection);
break;
}
}
Expand All @@ -446,6 +470,20 @@ sqlitefdw_xact_callback(XactEvent event, void *arg)
sqlitefdw_reset_xact_state(entry, true);
}

/* Execute again the query after server is available */
foreach(lc, busy_connection)
{
BusyHandlerArg *arg = lfirst(lc);

/*
* If there is still error, we can not do anything more, just raise it.
* requireBusyHandler is set to false, and NULL busy_connection list.
*/
sqlite_do_sql_command(arg->conn, arg->sql, arg->level, NULL);
}

list_free(busy_connection);

/*
* Regardless of the event type, we can now mark ourselves as out of the
* transaction. (Note: if we are here during PRE_COMMIT or PRE_PREPARE,
Expand Down Expand Up @@ -491,6 +529,8 @@ sqlitefdw_subxact_callback(SubXactEvent event, SubTransactionId mySubid,
HASH_SEQ_STATUS scan;
ConnCacheEntry *entry;
int curlevel;
ListCell *lc;
List *busy_connection = NIL;

/* Nothing to do at subxact start, nor after commit. */
if (!(event == SUBXACT_EVENT_PRE_COMMIT_SUB ||
Expand Down Expand Up @@ -529,7 +569,7 @@ sqlitefdw_subxact_callback(SubXactEvent event, SubTransactionId mySubid,
{
/* Commit all remote subtransactions during pre-commit */
snprintf(sql, sizeof(sql), "RELEASE SAVEPOINT s%d", curlevel);
sqlite_do_sql_command(entry->conn, sql, ERROR);
sqlite_do_sql_command(entry->conn, sql, ERROR, &busy_connection);

}
else if (in_error_recursion_trouble())
Expand All @@ -542,12 +582,26 @@ sqlitefdw_subxact_callback(SubXactEvent event, SubTransactionId mySubid,
else
{
/* Rollback all remote subtransactions during abort */
sqlitefdw_abort_cleanup(entry, false);
sqlitefdw_abort_cleanup(entry, false, &busy_connection);
}

/* OK, we're outta that level of subtransaction */
sqlitefdw_reset_xact_state(entry, false);
}

/* Execute again the query after server is available */
foreach(lc, busy_connection)
{
BusyHandlerArg *arg = lfirst(lc);

/*
* If there is still error, we can not do anything more, just raise it.
* requireBusyHandler is set to false, and NULL busy_connection list.
*/
sqlite_do_sql_command(arg->conn, arg->sql, arg->level, NULL);
}

list_free(busy_connection);
}

/*
Expand Down Expand Up @@ -812,7 +866,7 @@ sqlite_fdw_disconnect_all(PG_FUNCTION_ARGS)
* rollbacked, false otherwise.
*/
static void
sqlitefdw_abort_cleanup(ConnCacheEntry *entry, bool toplevel)
sqlitefdw_abort_cleanup(ConnCacheEntry *entry, bool toplevel, List **busy_connection)
{
if (toplevel)
{
Expand All @@ -826,7 +880,7 @@ sqlitefdw_abort_cleanup(ConnCacheEntry *entry, bool toplevel)
* already rollback
*/
if (!sqlite3_get_autocommit(entry->conn))
sqlite_do_sql_command(entry->conn, "ROLLBACK", WARNING);
sqlite_do_sql_command(entry->conn, "ROLLBACK", WARNING, busy_connection);
}
else
{
Expand All @@ -836,7 +890,7 @@ sqlitefdw_abort_cleanup(ConnCacheEntry *entry, bool toplevel)
"ROLLBACK TO SAVEPOINT s%d; RELEASE SAVEPOINT s%d",
curlevel, curlevel);
if (!sqlite3_get_autocommit(entry->conn))
sqlite_do_sql_command(entry->conn, sql, ERROR);
sqlite_do_sql_command(entry->conn, sql, ERROR, busy_connection);
}
}

Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -1473,14 +1473,14 @@ SELECT * FROM noprimary;
SELECT * FROM public.sqlite_fdw_version();
sqlite_fdw_version
--------------------
20200
20300
(1 row)

--Testcase 155:
SELECT sqlite_fdw_version();
sqlite_fdw_version
--------------------
20200
20300
(1 row)

-- issue #44 github
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -1473,14 +1473,14 @@ SELECT * FROM noprimary;
SELECT * FROM public.sqlite_fdw_version();
sqlite_fdw_version
--------------------
20200
20300
(1 row)

--Testcase 155:
SELECT sqlite_fdw_version();
sqlite_fdw_version
--------------------
20200
20300
(1 row)

-- issue #44 github
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
4 changes: 2 additions & 2 deletions expected/13.7/sqlite_fdw.out → expected/13.8/sqlite_fdw.out
Original file line number Diff line number Diff line change
Expand Up @@ -1473,14 +1473,14 @@ SELECT * FROM noprimary;
SELECT * FROM public.sqlite_fdw_version();
sqlite_fdw_version
--------------------
20200
20300
(1 row)

--Testcase 155:
SELECT sqlite_fdw_version();
sqlite_fdw_version
--------------------
20200
20300
(1 row)

-- issue #44 github
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -1455,14 +1455,14 @@ SELECT * FROM noprimary;
SELECT * FROM public.sqlite_fdw_version();
sqlite_fdw_version
--------------------
20200
20300
(1 row)

--Testcase 155:
SELECT sqlite_fdw_version();
sqlite_fdw_version
--------------------
20200
20300
(1 row)

-- issue #44 github
Expand Down
File renamed without changes.
File renamed without changes.
Loading

0 comments on commit 3a495b7

Please sign in to comment.