Android Room數(shù)據(jù)庫(kù)容易遇到的問(wèn)題以及解決方法
1.Android Room 數(shù)據(jù)庫(kù)的坑
在用Room數(shù)據(jù)庫(kù)的時(shí)候 發(fā)現(xiàn)有需要一個(gè)字段的條件合到一起去寫這個(gè)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里面獨(dú)特的表達(dá)方式 是替代了java里面的“+”號(hào)
正常在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 查詢語(yǔ)句的坑
@Query("SELECT * FROM 表名 WHERE 字段A = '0' order by id desc")
List selectList();假如你正在查詢一張表的面的內(nèi)容,然后忽然跑出來(lái)一個(gè)異常
# [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對(duì)應(yīng)的Sqlite數(shù)據(jù)庫(kù),其對(duì)CursorWindows分配的大小是有限制的,最大為2M,超過(guò)之后會(huì)發(fā)生上述崩潰閃退現(xiàn)象(偶現(xiàn)且難以復(fù)現(xiàn)的bug)
解決方法
需要業(yè)務(wù)方梳理這塊的業(yè)務(wù),優(yōu)化數(shù)據(jù)庫(kù)的調(diào)用,如果明確知道在一個(gè)方法里面會(huì)調(diào)用多個(gè)數(shù)據(jù)庫(kù)的方法,需要讓 controller 提供新的方法,且這個(gè) controller 層的方法需要添加 @Transaction 進(jìn)行注解,從而保證在同一個(gè)事物內(nèi)進(jìn)行數(shù)據(jù)庫(kù)操作,以此避免 CursorWindows 大小超過(guò) 2M
那么問(wèn)題來(lái)了 @Transaction 這個(gè)注解是干嘛的呢
翻譯 事務(wù)的意思
@Transaction
@Query("SELECT * FROM 表名 WHERE 字段A = '0' order by id desc")
List selectList();接著 問(wèn)題完美解決
到此這篇關(guān)于Android Room數(shù)據(jù)庫(kù)容易遇到的問(wèn)題以及解決方法的文章就介紹到這了,更多相關(guān)Android Room數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android實(shí)現(xiàn)圖片拖動(dòng)效果
本文主要介紹了Android實(shí)現(xiàn)圖片拖動(dòng)效果的實(shí)例,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03
Android中GPS坐標(biāo)轉(zhuǎn)換為高德地圖坐標(biāo)詳解
最近因?yàn)楣拘枨?,在做GPS定位,并且將獲得的坐標(biāo)顯示在高德地圖上,但是實(shí)際效果跟我們期望的是有偏差的。通過(guò)查閱資料,才知道有地球坐標(biāo)、火星坐標(biāo)之說(shuō)。下面這篇文章就詳細(xì)介紹了Android中GPS坐標(biāo)轉(zhuǎn)換為高德地圖坐標(biāo)的方法,需要的朋友可以參考下。2017-01-01
Android開場(chǎng)動(dòng)畫類完整實(shí)現(xiàn)代碼
這篇文章主要介紹了Android開場(chǎng)動(dòng)畫類完整實(shí)現(xiàn)代碼,是非常實(shí)用的功能,需要的朋友可以參考下2014-07-07
Android?Springboot?實(shí)現(xiàn)SSE通信案例詳解
SSE是一種用于實(shí)現(xiàn)服務(wù)器主動(dòng)向客戶端推送數(shù)據(jù)的技術(shù),它基于?HTTP?協(xié)議,利用了其長(zhǎng)連接特性,在客戶端與服務(wù)器之間建立一條持久化連接,并通過(guò)這條連接實(shí)現(xiàn)服務(wù)器向客戶端的實(shí)時(shí)數(shù)據(jù)推送,這篇文章主要介紹了Android?Springboot?實(shí)現(xiàn)SSE通信案例,需要的朋友可以參考下2024-07-07
Android自定義控件ViewFipper實(shí)現(xiàn)豎直跑馬燈效果
這篇文章主要為大家詳細(xì)介紹了Android自定義控件ViewFipper實(shí)現(xiàn)豎直跑馬燈效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12
Android基于OpenGL的GLSurfaceView創(chuàng)建一個(gè)Activity實(shí)現(xiàn)方法
這篇文章主要介紹了Android基于OpenGL的GLSurfaceView創(chuàng)建一個(gè)Activity實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了Android中OpenGL圖形操作類GLSurfaceView的功能、用法及相關(guān)使用技巧,需要的朋友可以參考下2016-10-10
Android 點(diǎn)擊editview以外位置實(shí)現(xiàn)隱藏輸入法
這篇文章主要介紹了Android 點(diǎn)擊editview以外位置實(shí)現(xiàn)隱藏輸入法的相關(guān)資料,需要的朋友可以參考下2017-06-06
Android動(dòng)態(tài)添加view的方法示例
本篇文章主要介紹了Android動(dòng)態(tài)添加view的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10

