From 922786571b6a0ddfe00dee0e5eeb36ec0be7d39f Mon Sep 17 00:00:00 2001 From: Mark Raasveldt Date: Wed, 4 Sep 2024 15:37:24 +0200 Subject: [PATCH] Fix #104: make CREATE OR REPLACE TABLE work in SQLite catalog instead of throwing an exception --- src/storage/sqlite_schema_entry.cpp | 3 +++ .../sql/storage/attach_create_or_replace.test | 21 +++++++++++++++++++ 2 files changed, 24 insertions(+) create mode 100644 test/sql/storage/attach_create_or_replace.test diff --git a/src/storage/sqlite_schema_entry.cpp b/src/storage/sqlite_schema_entry.cpp index d5ddf1d..72e2392 100644 --- a/src/storage/sqlite_schema_entry.cpp +++ b/src/storage/sqlite_schema_entry.cpp @@ -284,6 +284,9 @@ void SQLiteSchemaEntry::DropEntry(ClientContext &context, DropInfo &info) { } auto table = GetEntry(GetCatalogTransaction(context), info.type, info.name); if (!table) { + if (info.if_not_found == OnEntryNotFound::RETURN_NULL) { + return; + } throw InternalException("Failed to drop entry \"%s\" - could not find entry", info.name); } auto &transaction = SQLiteTransaction::Get(context, catalog); diff --git a/test/sql/storage/attach_create_or_replace.test b/test/sql/storage/attach_create_or_replace.test new file mode 100644 index 0000000..b4d8113 --- /dev/null +++ b/test/sql/storage/attach_create_or_replace.test @@ -0,0 +1,21 @@ +# name: test/sql/storage/attach_create_or_replace.test +# description: +# group: [sqlite_storage] + +require sqlite_scanner + +statement ok +ATTACH '__TEST_DIR__/attach_unnest.sqlite' AS tmp (TYPE SQLITE); + +statement ok +USE tmp; + +statement ok +CREATE OR REPLACE TABLE xs AS SELECT unnest(['foo', 'bar', 'baz']) AS x; + +query I +SELECT * FROM xs; +---- +foo +bar +baz