登录
首页 >  Golang >  Go问答

VACUUM INTO 内存数据库

来源:stackoverflow

时间:2024-04-08 14:18:33 326浏览 收藏

从现在开始,我们要努力学习啦!今天我给大家带来《VACUUM INTO 内存数据库》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!

问题内容

我正在尝试将 sqlite 文件加载到内存中。

我像这里一样使用“vacuum into”,但我的内存数据库仍然是空的。

我不知道出了什么问题。 :

diskDbPath := `file:C:\test.db`
memDbPath := "file:memdb?mode=memory&cache=shared"

diskDb, _ := sql.Open("sqlite3", diskDbPath)

rowcount := 0
diskDb.QueryRow("SELECT count(*) FROM sqlite_master WHERE type = 'table'").Scan(&rowcount)
fmt.Println("disk db:", rowcount, "tables")

memDb, _ := sql.Open("sqlite3", memDbPath)

_, err := diskDb.Exec("VACUUM INTO '" + memDbPath + "'; ")
if err != nil {
    panic(err)
}

memDb.QueryRow("SELECT count(*) FROM sqlite_master WHERE type = 'table'").Scan(&rowcount)
fmt.Println("mem db:", rowcount, "tables")

/*
output :
disk db: 9 tables
mem db: 0 tables
*/

驱动程序:github.com/mattn/go-sqlite3 v1.14.7,go版本:go1.16.2 windows/amd64


正确答案


尝试了几次之后... 如果您在真空之前对内存基础执行 ping 操作,则似乎可以工作。 我猜想内存数据库在没有第一次接触的情况下并没有真正初始化。

diskDbPath := `file:C:\test.db`
memDbPath := "file:memdb?mode=memory&cache=shared"

diskDb, _ := sql.Open("sqlite3", diskDbPath)

rowcount := 0
diskDb.QueryRow("SELECT count(*) FROM sqlite_master WHERE type = 'table'").Scan(&rowcount)
fmt.Println("disk db:", rowcount, "tables")

memDb, _ := sql.Open("sqlite3", memDbPath)
memDb.Ping() // <

_, err := diskDb.Exec("VACUUM INTO '" + memDbPath + "'; ")
if err != nil {
    panic(err)
}

memDb.QueryRow("SELECT count(*) FROM sqlite_master WHERE type = 'table'").Scan(&rowcount)
fmt.Println("mem db:", rowcount, "tables")

/*
output :
disk db: 9 tables
mem db: 9 tables
*/

终于介绍完啦!小伙伴们,这篇关于《VACUUM INTO 内存数据库》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>