ホームページ >バックエンド開発 >Golang >Go の SQLite3 で「データベースがロックされています」エラーを回避するには?

Go の SQLite3 で「データベースがロックされています」エラーを回避するには?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-15 22:20:17391ブラウズ

How to Avoid the

Go を使用した SQLite3 の「データベースがロックされています」エラーの処理

Go で SQLite3 データベースを操作する場合、ユーザーは「データベースがロックされています」エラーが発生する可能性があります。このエラーは、同じデータベース ファイルにアクセスしようとしている複数の同時スレッドの存在を示唆しています。

この問題を解決するには、プログラム内でデータベースへの接続が 1 つだけ維持されていることを確認してください。クエリ結果を閉じることは不可欠ですが、複数のデータベース ファイル ハンドルの作成を考慮することも重要です。

次のコード スニペットは問題を示しています。

func main() {
    database, tx, err := getDatabaseHandle()
    if err != nil {
        log.Fatal(err)
    }
    defer database.Close()
    dosomething(database, tx)
}

func dosomething(database *sql.DB, tx *sql.Tx) error {
    rows, err := database.Query("select * from sometable where name=?", "some")
    if err != nil {
        return err
    }

    defer rows.Close() // Deferring the rows.Close() helps resolve the issue

    if rows.Next() {
        ...
    }
    rows.Close()
    //some insert queries
    tx.Commit()
}

遅延行の追加に注意してください。 dosomething 関数内の Close()。これにより、データベース ファイル ハンドルが即座に解放され、複数のハンドルの作成が防止されます。

このアプローチに従うことで、Go で SQLite3 データベース接続を効果的に管理し、「データベースがロックされています」エラーを回避できます。

以上がGo の SQLite3 で「データベースがロックされています」エラーを回避するには?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。