首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Android在哪里存储SQLite的数据库版本?

Android在哪里存储SQLite的数据库版本?
EN

Stack Overflow用户
提问于 2010-09-14 17:53:19
回答 2查看 28.5K关注 0票数 90

我找不到Android在SQLite数据库文件中存储数据库版本的位置。数据库版本到底存储在哪里?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-09-15 02:52:57

您可以使用android.database.sqlite.SQLiteDatabase.getVersion()读取版本。

在内部,此方法执行SQL语句"PRAGMA user_version“。这是我从Android source code得到的。

在数据库文件中,版本存储在数据库文件的database header中的字节偏移量60处,在字段'user cookie‘中。

票数 190
EN

Stack Overflow用户

发布于 2015-08-04 07:59:11

如果有人正在寻找要从文件中读取版本的java代码:

代码语言:javascript
复制
private static int getDbVersionFromFile(File file) throws Exception
{
    RandomAccessFile fp = new RandomAccessFile(file,"r");
    fp.seek(60);
    byte[] buff = new byte[4];
    fp.read(buff, 0, 4);
    return ByteBuffer.wrap(buff).getInt();
}
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3707797

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档