我正在使用带有CursorLoader
的Ormlite,使用ormlite-extras库(我使用包support.extras
,因为我打算将android 2.2及更高版本作为目标)。
我有以下例外:
FATAL EXCEPTION: main
java.lang.IllegalArgumentException: column '_id' does not exist
at android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:314)
at android.support.v4.widget.CursorAdapter.swapCursor(CursorAdapter.java:344)
at rainstudios.meleo.ui.eventlv.EventLvFragment.onLoadFinished(EventLvFragment.java:274)
at rainstudios.meleo.ui.eventlv.EventLvFragment.onLoadFinished(EventLvFragment.java:1)
at android.support.v4.app.LoaderManagerImpl$LoaderInfo.callOnLoadFinished(LoaderManager.java:427)
at android.support.v4.app.LoaderManagerImpl$LoaderInfo.onLoadComplete(LoaderManager.java:395)
at android.support.v4.content.Loader.deliverResult(Loader.java:103)
at rainstudios.meleo.data.RainstudiosOrmliteCursorLoader.deliverResult(RainstudiosOrmliteCursorLoader.java:68)
at rainstudios.meleo.data.RainstudiosOrmliteCursorLoader.deliverResult(RainstudiosOrmliteCursorLoader.java:1)
at android.support.v4.content.AsyncTaskLoader.dispatchOnLoadComplete(AsyncTaskLoader.java:221)
at android.support.v4.content.AsyncTaskLoader$LoadTask.onPostExecute(AsyncTaskLoader.java:61)
at android.support.v4.content.ModernAsyncTask.finish(ModernAsyncTask.java:461)
at android.support.v4.content.ModernAsyncTask.access$500(ModernAsyncTask.java:47)
at android.support.v4.content.ModernAsyncTask$InternalHandler.handleMessage(ModernAsyncTask.java:474)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:130)
at android.app.ActivityThread.main(ActivityThread.java:3835)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
at dalvik.system.NativeStart.main(Native Method)
我做了一些挖掘并注意到CursorLoader中的代码返回的'_id'
中确实没有results
。
有关详细信息,请参阅上面的代码:
/* Runs on a worker thread */
@Override
public Cursor loadInBackground() {
Cursor cursor = null;
try {
CloseableIterator<T> iterator = mDao.iterator(mQuery);
// get the raw results which can be cast under Android
AndroidDatabaseResults results = (AndroidDatabaseResults) iterator
.getRawResults();
cursor = results.getRawCursor();
} catch (SQLException e) {
e.printStackTrace();
}
if (cursor != null) {
// Ensure the cursor window is filled
cursor.getCount();
registerContentObserver(cursor, mObserver);
}
return cursor;
}
使用调试器,显示如下:
results.columnNameMap = [id, code, name, popular, rating, voteCount, shortDescription, description, hoursDescription, url, modificationDate, syncDate, artist_id, district_id, pictures, frontPicture, userRating, venue_id, userComment, userFavorite, situation_id, caFrontPictureId, caResources]
results.columnNames = {syncDate=11, userRating=16, district_id=13, pictures=14, userFavorite=19, artist_id=12, code=1, situation_id=20, frontPicture=15, voteCount=5, url=9, caResources=22, id=0, hoursDescription=8, userComment=18, shortDescription=6, description=7, popular=3, name=2, venue_id=17, rating=4, caFrontPictureId=21, modificationDate=10}
准备好的查询的创建非常标准:
public PreparedQuery<EventDb> findAllEventsQuery() {
try {
QueryBuilder<EventDb, Integer> eventQb = getEventDao()
.queryBuilder();
return eventQb.prepare();
} catch (Throwable e) {
Out.handleSilentError("Cannot retrieve all events", e);
}
return null;
}
我做了测试,执行查询并将结果作为List:一切正常。
现在,我很困惑。
此外,我还为ormlite专家提供了另一个。
iterator.closeQuietly()
来关闭迭代器吗?答案 0 :(得分:3)
正如@patheticpat所指出的,该解决方案可在stackoverflow上使用:ORMLite with CursorAdapter in Android
您的ID字段需要要映射到名为_id的列,以使用带有Ormlite
4.42的Cursor。
像这样:
@DatabaseTable(tableName = "event")
public class EventDb extends BaseDaoEnabled<EventDb, Integer> {
@DatabaseField(generatedId = true, columnName = "_id")
int id;
注意:您无法拨打iterator.closeQuietly()
,因为它崩溃了。
我希望没有记忆泄露,因为如果那样。