33

我有一个大小超过 2.6 GiB 的 SQLite 数据库。(数据库包含地图。)此数据库由 RMaps 应用程序使用。当以最大缩放将地图移动到某些部分时,应用程序突然关闭。但是,没有强制关闭消息,没有报告按钮。所以,我有一个想法,它是由读取超出某个限制的块引起的,例如 max(int)。由于 RMaps 只是使用简单的 SQL 语句,我认为问题不在于 RMaps,而在于 Android SQLite 驱动程序。

Android 上的 SQLite 数据库有大小限制吗?

(我在 Nexus One 上有 Froyo,但我不认为这只是 Froyo 的问题。)

日志输出:

08-14 10:24:51.689 I/ActivityManager(   81): Starting activity: Intent { act=android.intent.action.SEARCH flg=0x10000000 cmp=com.robert.maps/.MainMapActivity (has extras) }
08-14 10:25:01.879 E/AndroidRuntime(12441): FATAL EXCEPTION: pool-1-thread-2
08-14 10:25:01.879 E/AndroidRuntime(12441): android.database.sqlite.SQLiteDiskIOException: disk I/O error
08-14 10:25:01.879 E/AndroidRuntime(12441):     at android.database.sqlite.SQLiteQuery.native_fill_window(Native Method)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at android.database.sqlite.SQLiteQuery.fillWindow(SQLiteQuery.java:70)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at android.database.sqlite.SQLiteCursor.fillWindow(SQLiteCursor.java:283)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at android.database.sqlite.SQLiteCursor.getCount(SQLiteCursor.java:264)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at android.database.AbstractCursor.moveToPosition(AbstractCursor.java:171)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at android.database.AbstractCursor.moveToFirst(AbstractCursor.java:248)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at com.robert.maps.utils.CashDatabase.getTile(CashDatabase.java:49)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at org.andnav.osm.views.util.OpenStreetMapTileFilesystemProvider$7.run(OpenStreetMapTileFilesystemProvider.java:501)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1068)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
08-14 10:25:01.879 E/AndroidRuntime(12441):     at java.lang.Thread.run(Thread.java:1096)
08-14 10:25:01.889 I/ActivityManager(   81): Process com.robert.maps (pid 12441) has died.
08-14 10:25:01.899 I/WindowManager(   81): WIN DEATH: Window{45131410 com.robert.maps/com.robert.maps.MainMapActivity paused=false}

SQLite 数据库存储在 SD 卡上,有足够的空间。

4

4 回答 4

18

字符串或 BLOB 的最大长度 默认大小为 1 GB 最大大小为 2.147483647

最大列数 默认大小为 2000 最大大小为 32767

SQL 语句的最大长度默认大小为 1 MB 最大大小为 1.073741824

连接中的最大表数默认为 64 个表

附加数据库的最大数量默认为 10 最大大小为 125

表最大行数最大为 18446744073.709552765

最大数据库大小 140 tb,但这取决于您的设备磁盘大小。

于 2015-02-16T06:35:10.920 回答
13

我怀疑它大约是 2 GB(这可能是由于 32 位架构,尽管某些程序带有大文件支持,允许更多)。幸运的是android.database.sqlite.SQLiteDatabase,有以下 API 调用返回数据库可能增长到的最大大小:

long getMaximumSize()

最终你可能想研究数据库分片;)

于 2010-08-22T07:36:14.273 回答
4

SQlite 有几个限制 ( http://www.sqlite.org/limits.html ) 可以与任何数据库一起使用。你试过vaccum;ing 这个特定的数据库吗?它将重建结构。您可能有一定程度的损坏,或者您已经达到了其他编译​​限制之一,以确保数据库不会成为漏洞利用向量。

于 2011-05-13T21:29:28.180 回答
1

我很难获得有关这方面的可靠信息,但变量太多了。此演示 Xamarin 应用程序允许您将您自己的 JSON 对象的示例以您想要的速度重复添加到 SQLite 数据库,直到您停止它。允许您查看对数据库大小和应用程序性能的影响。它很粗糙,但很好地满足了我的目的,希望这可以帮助其他人,或者您可以扩展它。你可以在这里找到它。

于 2017-07-31T16:49:48.107 回答