SQLite 中间歇性表丢失错误:内存:数据库

sqlite 中间歇性表丢失错误:内存:数据库

php小编香蕉为你带来关于SQLite中间歇性表丢失错误的解决方法。当我们使用SQLite数据库时,可能会遇到内存错误或者表丢失的情况。这种错误通常是由于不正确的数据库操作或者内存问题引起的。为了解决这个问题,我们可以采取一些措施,如优化查询语句、增加内存限制等。在本文中,我们将详细介绍如何排查和解决这个问题,以确保数据库的正常运行。

问题内容

我们通过 github.com/mattn/go-sqlite3 v1.14.16 在 Go 中使用 SQLite 3.39.4。连接字符串为 ":memory:?cache=shared&mode=rwc&_mutex=no&_journal=WAL&_sync=NORMAL"

我们偶尔会在测试中看到错误“没有这样的表:配置”。令人困惑的是,有问题的查询已经在测试用例中成功使用,并且该表随后显示在 sqlite_master 的查询中,无论是在数据库连接还是引发错误的事务对象中。但是,一旦发生错误,查询就不会再成功。

我意识到这是一个相当模糊的问题,但有人至少可以建议去哪里看吗?数据库连接始终具有相同的指针值。

更新:

第二次尝试时,我几乎可以在此 SSCCE 中重现问题:

package main import ( "database/sql" "fmt" _ "github.com/mattn/go-sqlite3" "os" ) func main() { os.Remove("example.db") db, err := sql.Open("sqlite3", ":memory:") if err != nil { panic(err) } for _, s := range []string{ "CREATE TABLE if not exists Configuration (" + "`id` varchar(1024) NOT NULL," + "`body` varchar(10240) DEFAULT NULL, " + "PRIMARY KEY (id) " + ")", "INSERT INTO Configuration (id, body) VALUES ('some-unique-value', 'another-unique-value')", } { _, err = db.Exec(s) if err != nil { panic(err) } } for i := 0; i 登录后复制