From 49523ff15029b8b424ef68a610652412b5284c7e Mon Sep 17 00:00:00 2001 From: Kjell Konis Date: Tue, 5 Mar 2024 05:52:45 -0800 Subject: [PATCH] Added Id method for dbExistsTable to address issue #498 --- DESCRIPTION | 1 + NAMESPACE | 1 + R/dbExistsTable_SQLiteConnection_Id.R | 27 +++++++++++++++++++++++++++ man/SQLiteConnection-class.Rd | 5 +++++ 4 files changed, 34 insertions(+) create mode 100644 R/dbExistsTable_SQLiteConnection_Id.R diff --git a/DESCRIPTION b/DESCRIPTION index 7fef36f3e..27aa6f11d 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -89,6 +89,7 @@ Collate: 'dbDataType_SQLiteConnection.R' 'dbDataType_SQLiteDriver.R' 'dbDisconnect_SQLiteConnection.R' + 'dbExistsTable_SQLiteConnection_Id.R' 'dbExistsTable_SQLiteConnection_character.R' 'dbFetch_SQLiteResult.R' 'dbGetException_SQLiteConnection.R' diff --git a/NAMESPACE b/NAMESPACE index 7d2daab12..e96ef151a 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -84,6 +84,7 @@ exportMethods(sqlData) import(DBI) import(methods) import(rlang) +importFrom(DBI,Id) importFrom(bit64,integer64) importFrom(bit64,is.integer64) importFrom(blob,blob) diff --git a/R/dbExistsTable_SQLiteConnection_Id.R b/R/dbExistsTable_SQLiteConnection_Id.R new file mode 100644 index 000000000..056b181e3 --- /dev/null +++ b/R/dbExistsTable_SQLiteConnection_Id.R @@ -0,0 +1,27 @@ +#' @rdname SQLiteConnection-class +#' @usage NULL +dbExistsTable_SQLiteConnection_Id <- function(conn, name, ...) { + stopifnot(is(name, "Id")) + + id <- as.list(dbUnquoteIdentifier(conn, dbQuoteIdentifier(conn, name))[[1]]@name) + schema <- id$schema + table <- id$table + + if (!is.null(schema)) { + schemas <- dbGetQuery(conn, "SELECT name FROM pragma_database_list;")$name + + if (!(schema %in% schemas)) { + return(FALSE) + } + } + + sql <- sqliteListTablesQuery(conn, schema, SQL("$name")) + rs <- dbSendQuery(conn, sql) + dbBind(rs, list(name = tolower(table))) + on.exit(dbClearResult(rs), add = TRUE) + + nrow(dbFetch(rs, 1L)) > 0 +} +#' @rdname SQLiteConnection-class +#' @export +setMethod("dbExistsTable", c("SQLiteConnection", "Id"), dbExistsTable_SQLiteConnection_Id) diff --git a/man/SQLiteConnection-class.Rd b/man/SQLiteConnection-class.Rd index 7c1a035dc..16b1c3e31 100644 --- a/man/SQLiteConnection-class.Rd +++ b/man/SQLiteConnection-class.Rd @@ -1,6 +1,7 @@ % Generated by roxygen2: do not edit by hand % Please edit documentation in R/SQLiteConnection.R, % R/dbAppendTable_SQLiteConnection.R, R/dbDataType_SQLiteConnection.R, +% R/dbExistsTable_SQLiteConnection_Id.R, % R/dbExistsTable_SQLiteConnection_character.R, % R/dbGetException_SQLiteConnection.R, R/dbGetInfo_SQLiteConnection.R, % R/dbIsValid_SQLiteConnection.R, R/dbListTables_SQLiteConnection.R, @@ -18,6 +19,8 @@ \alias{dbAppendTable,SQLiteConnection-method} \alias{dbDataType_SQLiteConnection} \alias{dbDataType,SQLiteConnection-method} +\alias{dbExistsTable_SQLiteConnection_Id} +\alias{dbExistsTable,SQLiteConnection,Id-method} \alias{dbExistsTable_SQLiteConnection_character} \alias{dbExistsTable,SQLiteConnection,character-method} \alias{dbGetException_SQLiteConnection} @@ -50,6 +53,8 @@ \S4method{dbDataType}{SQLiteConnection}(dbObj, obj, ...) +\S4method{dbExistsTable}{SQLiteConnection,Id}(conn, name, ...) + \S4method{dbExistsTable}{SQLiteConnection,character}(conn, name, ...) \S4method{dbGetException}{SQLiteConnection}(conn, ...)