Created
March 24, 2025 06:45
-
-
Save wjkoh/a2cfdd1c4f1b99687cde6714d1d7b885 to your computer and use it in GitHub Desktop.
Go + SQLite3: Temporary Table Not Removed
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package main | |
import ( | |
"context" | |
"database/sql" | |
"log" | |
"os" | |
_ "github.com/mattn/go-sqlite3" | |
) | |
func main() { | |
err := createTempTableTwice(context.Background()) | |
if err != nil { | |
log.Fatal(err) | |
} | |
log.Println("Done.") | |
} | |
func createTempTableTwice(ctx context.Context) error { | |
os.Remove("./foo.db") | |
db, err := sql.Open("sqlite3", "./foo.db") | |
if err != nil { | |
log.Fatal(err) | |
} | |
defer db.Close() | |
{ | |
conn1, err := db.Conn(ctx) | |
if err != nil { | |
return err | |
} | |
_, err = conn1.ExecContext(ctx, `CREATE TEMPORARY TABLE temp.documents(document_id TEXT PRIMARY KEY);`) | |
if err != nil { | |
return err | |
} | |
err = conn1.Close() | |
if err != nil { | |
return err | |
} | |
} | |
conn2, err := db.Conn(ctx) | |
if err != nil { | |
return err | |
} | |
defer conn2.Close() | |
// NOTE: This line causes the following error: `2025/03/24 15:42:40 table documents already exists` | |
_, err = conn2.ExecContext(ctx, `CREATE TEMPORARY TABLE temp.documents(document_id TEXT PRIMARY KEY);`) | |
return err | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Check out mattn/go-sqlite3#1330