Android Room數(shù)據(jù)庫容易遇到的問題以及解決方法
1.Android Room 數(shù)據(jù)庫的坑
在用Room數(shù)據(jù)庫的時候 發(fā)現(xiàn)有需要一個字段的條件合到一起去寫這個SQL
@Query("SELECT * FROM 表名 WHERE 字段A = '1' and 字段B <= :Time " + "and 字段B >= :Time and 字段C <= :BTime and 字段C >= :BTime " + "and '(' || 字段D is null or 字段D = '' || ')'") List selectList(String Time, String BTime);
這里面的 “ ||” 是Room里面獨特的表達方式 是替代了java里面的“+”號
正常在android中 使用 是這樣的
String sql = "SELECT * FROM 表名 WHERE 字段A = '1' and 字段B <= "+傳入的參數(shù)+" " + "and 字段B >= "+傳入的參數(shù)+" and 字段C <= "+傳入的參數(shù)+" and 字段c >= "+傳入的參數(shù)+" " + "and '(' "+" 字段D is null or 字段D = '' "+" ')'" cursor = db.rawQuery(sql, null);
而在Room 中 用 “||” 代替了 “+”
2.Android Room 查詢語句的坑
@Query("SELECT * FROM 表名 WHERE 字段A = '0' order by id desc") List selectList();
假如你正在查詢一張表的面的內(nèi)容,然后忽然跑出來一個異常
# [Android RoomDatabase Cruash "Cursor window allocation of 4194304 bytes failed"](https://stackoverflow.com/questions/75456123/android-roomdatabase-cruash-cursor-window-allocation-of-4194304-bytes-failed)
奔潰日志:
android.database.CursorWindowAllocationException: Could not allocate CursorWindow '/data/user/0/cn.xxx.xxx/databases/xxx.db' of size 2097152 due to error -13. at android.database.CursorWindow.nativeCreate(Native Method) at android.database.CursorWindow.<init>(CursorWindow.java:139) at android.database.CursorWindow.<init>(CursorWindow.java:120) at android.database.AbstractWindowedCursor.clearOrCreateWindow(AbstractWindowedCursor.java:202) at android.database.sqlite.SQLiteCursor.fillWindow(SQLiteCursor.java:147) at android.database.sqlite.SQLiteCursor.getCount(SQLiteCursor.java:140) at yd.d.m(SourceFile:21) at cn.xxx.control.y.y0(SourceFile:1) at e5.y.p(SourceFile:230) at e5.y.l(SourceFile:1) at e5.y.E(SourceFile:1) at cn.xxx.cluster.classin.viewmodel.SessionViewModel$d.invokeSuspend(SourceFile:42)
觸發(fā)原因
Room
對應(yīng)的Sqlite
數(shù)據(jù)庫,其對CursorWindows
分配的大小是有限制的,最大為2M
,超過之后會發(fā)生上述崩潰閃退現(xiàn)象(偶現(xiàn)且難以復(fù)現(xiàn)的bug
)
解決方法
需要業(yè)務(wù)方梳理這塊的業(yè)務(wù),優(yōu)化數(shù)據(jù)庫的調(diào)用,如果明確知道在一個方法里面會調(diào)用多個數(shù)據(jù)庫的方法,需要讓 controller 提供新的方法,且這個 controller 層的方法需要添加 @Transaction 進行注解,從而保證在同一個事物內(nèi)進行數(shù)據(jù)庫操作,以此避免 CursorWindows 大小超過 2M
那么問題來了 @Transaction
這個注解是干嘛的呢
翻譯 事務(wù)的意思
@Transaction @Query("SELECT * FROM 表名 WHERE 字段A = '0' order by id desc") List selectList();
接著 問題完美解決
到此這篇關(guān)于Android Room數(shù)據(jù)庫容易遇到的問題以及解決方法的文章就介紹到這了,更多相關(guān)Android Room數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android中GPS坐標(biāo)轉(zhuǎn)換為高德地圖坐標(biāo)詳解
最近因為公司需求,在做GPS定位,并且將獲得的坐標(biāo)顯示在高德地圖上,但是實際效果跟我們期望的是有偏差的。通過查閱資料,才知道有地球坐標(biāo)、火星坐標(biāo)之說。下面這篇文章就詳細介紹了Android中GPS坐標(biāo)轉(zhuǎn)換為高德地圖坐標(biāo)的方法,需要的朋友可以參考下。2017-01-01Android?Springboot?實現(xiàn)SSE通信案例詳解
SSE是一種用于實現(xiàn)服務(wù)器主動向客戶端推送數(shù)據(jù)的技術(shù),它基于?HTTP?協(xié)議,利用了其長連接特性,在客戶端與服務(wù)器之間建立一條持久化連接,并通過這條連接實現(xiàn)服務(wù)器向客戶端的實時數(shù)據(jù)推送,這篇文章主要介紹了Android?Springboot?實現(xiàn)SSE通信案例,需要的朋友可以參考下2024-07-07Android自定義控件ViewFipper實現(xiàn)豎直跑馬燈效果
這篇文章主要為大家詳細介紹了Android自定義控件ViewFipper實現(xiàn)豎直跑馬燈效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12Android基于OpenGL的GLSurfaceView創(chuàng)建一個Activity實現(xiàn)方法
這篇文章主要介紹了Android基于OpenGL的GLSurfaceView創(chuàng)建一個Activity實現(xiàn)方法,結(jié)合實例形式分析了Android中OpenGL圖形操作類GLSurfaceView的功能、用法及相關(guān)使用技巧,需要的朋友可以參考下2016-10-10Android 點擊editview以外位置實現(xiàn)隱藏輸入法
這篇文章主要介紹了Android 點擊editview以外位置實現(xiàn)隱藏輸入法的相關(guān)資料,需要的朋友可以參考下2017-06-06