我有一个代码:
public String getNameUpdateEvent(long id) { Cursor mCursor = db.rawQuery("select name from events WHERE _id=" + id + ";",null); if (mCursor != null) { mCursor.moveToFirst(); } String updateNameEvent; updateNameEvent = mCursor.getString(mCursor.getColumnIndex("name")); return updateNameEvent; }
我得到一个警告
Warning:(173,45) Method invocation 'mCursor.getColumnIndex("name")' may produce 'java.lang.NullPointerException'
我可以修复它吗?
解决方法
你的光标不能为null,它将始终有任何值.但是光标可以是空的,所以你应该首先使用moveToFirst()方法去游标中的第一行,如果它返回true,这意味着该游标至少有一行,所以你可以用它来完成所有的操作,如果它返回false – 这意味着您的查询没有任何内容,因此您没有任何行可以获取数据.你的代码应该是这样的:
public String getNameUpdateEvent(long id) { Cursor mCursor = db.rawQuery("select name from events WHERE _id=" + id + ";",null); String updateNameEvent = null; if (mCursor != null && mCursor.moveToFirst()) { updateNameEvent = mCursor.getString(mCursor.getColumnIndex("name")); } return updateNameEvent; }