Что такое максимальный размер базы данных SQLite на Android?

У меня есть база данных SQLite, размер которой превышает 2,6 ГБ. (БД содержит карты.) Эта база данных используется приложением RMaps. При перемещении карты в некоторые части с максимальным увеличением приложение внезапно закрывается. Тем не менее, нет принудительного закрытия сообщения, нет кнопки отчета. Итак, у меня есть идея, что это вызвано чтением блоков, которые находятся за определенным пределом, например, max (int). Поскольку RMaps просто использует простые операторы SQL, я думаю, что проблема не в RMaps, а скорее в драйвере Android SQLite.

Существует ли ограничение размера базы данных SQLite на Android?

(у меня Froyo на Nexus One, но я не думаю, что это просто проблема 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-карте, там достаточно места.

29
задан rekire 5 May 2012 в 13:44
поделиться

1 ответ

Я подозреваю, что это ~2 гигабайта (это может быть связано с 32-битной архитектурой, хотя некоторые программы поставляются с поддержкой больших файлов, что позволяет больше). К счастью, android.database.sqlite.SQLiteDatabase имеет следующий вызов API, который возвращает максимальный размер базы данных, до которого она может вырасти:

long getMaximumSize()

В конце концов, вы можете захотеть рассмотреть шардинг базы данных ;)

11
ответ дан 28 November 2019 в 02:00
поделиться
Другие вопросы по тегам:

Похожие вопросы: