169 похожих чатов

Caused by: android.database.sqlite.SQLiteDatabaseLockedException: database is locked (code 5 SQLITE_BUSY[5]): ,

while compiling: PRAGMA journal_mode

Кто знает как можно решить данную проблему?

7 ответов

22 просмотра

Не лезть в базу из двух разных процессов (потоков) одновременно. Работа с sqlite напрямую? Какой код это вызвал? Можно сделать методы обращения к DAO синхронизированными и единую точку входа

Vlad-Alekseevich Автор вопроса
Сергей П.
Не лезть в базу из двух разных процессов (потоков)...

Только из этой точки этого потока идёт вход

Вот тут все верно пишут I think you have forgotten to close the database, or another thread is writing to the database when you are trying to write to it. SQLite locks the database when it is writing to it to avoid corruption if another entity tries to write to the same database at the same time. Android, will only show a error in log cat, and the query you supplied will be just forgotten... So, I recommend: You only access the database from one SQLOpenHelper You make sure you close all instances of database helpers once you have finished with them You make sure you always end transactions with endTransaction() also if you do not set them successful (i.e. if you want to roll 'em back), in case you use transactions

Сергей П.
Вот тут все верно пишут I think you have forgotte...

Оберните код в теги: 3 символа ` до и после кода (в случае одиночной конструкции достаточно 1 ` с обеих сторон). Спасибо!

Vlad-Alekseevich Автор вопроса
Сергей П.
Вот тут все верно пишут I think you have forgotte...

Стоит после каждой операции закрывать?

Vlad Alekseevich
Стоит после каждой операции закрывать?

Транзакцию да. А хелпером просто пользуемся. Строго одним. И в классе репозитории можно все методы сделать synchronized

Vlad Alekseevich
Стоит после каждой операции закрывать?

Посмотри на сайте startandroid примеры работы с базой, примерно в первых 20 уроках несколько есть. У него все работало

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

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Карта сайта