How to tell if sqlite database file is valid or not

前端 未结 3 722
天涯浪人
天涯浪人 2021-02-19 02:06

In the code below, pathToNonDatabase is the path to a simple text file, not a real sqlite database. I was hoping for sqlite3_open to detect that, but

相关标签:
3条回答
  • 2021-02-19 02:31

    sqlite opens databases lazily. Just do something immediately after opening that requires it to be a database.

    The best is probably pragma schema_version;.

    • This will report 0 if the database hasn't been created (for instance, an empty file). In this case, it's safe work with (and run CREATE TABLE, etc)
    • If the database has been created, it will return how many revisions the schema has gone through. This value might not be interesting, but that it's not zero is.
    • If the file exists and isn't a database (or empty), you'll get an error.

    If you want a somewhat more thorough check, you can use pragma quick_check;. This is a lighter-weight integrity check, which skips checking that the contents of the tables line up with the indexes. It can still be very slow.

    Avoid integrity_check. It not only checks every page, but then verifies the contents of the tables against the indexes. This is positively glacial on a large database.

    0 讨论(0)
  • 2021-02-19 02:35

    I think a pragma integrity_check could do it.

    0 讨论(0)
  • 2021-02-19 02:48

    For anyone needing to do this in C# with System.Data.SQLite you can start a transaction, and then immediately roll it back as follows:-

        private bool DatabaseIsValid(string filename)
        {
            using (SQLiteConnection db = new SQLiteConnection(@"Data Source=" + filename + ";FailIfMissing=True;"))
            {
                try
                {
                    db.Open();
                    using (var transaction = db.BeginTransaction())
                    {
                        transaction.Rollback();
                    }
                }
                catch (Exception ex)
                {
                    log.Debug(ex.Message, ex);
                    return false;
                }
            }
            return true;
        }
    

    If the file is not a valid database the following SQLiteException is thrown - file is encrypted or is not a database (System.Data.SQLite.SQLiteErrorCode.NotADb). If you aren't using encrypted databases then this solution should be sufficient. (Only the 'db.Open()' was required for version 1.0.81.0 of System.Data.SQLite but when I upgraded to version 1.0.91.0 I had to insert the inner using block to get it to work).

    0 讨论(0)
提交回复
热议问题