Skip to content

Misleading ERROR: SQLiteException("out of memory") caused by closed database #324

Open
@wjholden

Description

@wjholden

I am creating this issue to hopefully help the next person who gets surprised by a misleading error message.

Suppose you build a SQLite database in Julia and you close it.

julia> using SQLite, DataFrames

julia> db = SQLite.DB("example.db");

julia> DBInterface.execute(db, "CREATE TABLE Example (ID INTEGER PRIMARY KEY)");

julia> DBInterface.execute(db, "INSERT INTO Example VALUES (1)");

julia> DBInterface.execute(db, "SELECT * FROM Example") |> DataFrame
1×1 DataFrame
 Row │ ID
     │ Int64
─────┼───────
   1 │     1

julia> close(db)

If you try to query the database again, you will get an "out of memory" error.

julia> DBInterface.execute(db, "SELECT * FROM Example") |> DataFrame
ERROR: SQLiteException("out of memory")
Stacktrace:
  [1] sqliteerror(args::SQLite.DB)
    @ SQLite C:\Users\wjhol\.julia\packages\SQLite\aeqsS\src\SQLite.jl:34
  [2] macro expansion
    @ C:\Users\wjhol\.julia\packages\SQLite\aeqsS\src\base.jl:10 [inlined]
  [3] prepare_stmt_wrapper
    @ C:\Users\wjhol\.julia\packages\SQLite\aeqsS\src\SQLite.jl:109 [inlined]
  [4] SQLite.Stmt(db::SQLite.DB, sql::String; register::Bool)
    @ SQLite C:\Users\wjhol\.julia\packages\SQLite\aeqsS\src\SQLite.jl:146
  [5] Stmt
    @ C:\Users\wjhol\.julia\packages\SQLite\aeqsS\src\SQLite.jl:145 [inlined]
  [6] prepare
    @ C:\Users\wjhol\.julia\packages\SQLite\aeqsS\src\SQLite.jl:180 [inlined]
  [7] execute
    @ C:\Users\wjhol\.julia\packages\DBInterface\1Gmxx\src\DBInterface.jl:130 [inlined]
  [8] #execute#2
    @ C:\Users\wjhol\.julia\packages\DBInterface\1Gmxx\src\DBInterface.jl:152 [inlined]
  [9] execute(conn::SQLite.DB, sql::String)
    @ DBInterface C:\Users\wjhol\.julia\packages\DBInterface\1Gmxx\src\DBInterface.jl:152
 [10] top-level scope
    @ REPL[7]:1

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions