获取游标中的行数时出错?

时间:2012-02-27 09:42:03

标签: android sqlite

我不知道为什么App。当我尝试显示游标内选定行的数量时崩溃。当我评论显示App所选行数的行。工作正常,否则会崩溃。

以下是代码:

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    dbd = new DBDemoActivity(this);
    db = dbd.getWritableDatabase();
    cv = new ContentValues();

    cv.put("name", "Amr");
    cv.put("lat", 10);
    cv.put("lng", 20);
    newID = db.insert("Demo", null, cv);

    cv.put("name", "Mikila");
    cv.put("lat", 14);
    cv.put("lng", 22);
    newID = db.insert("Demo", null, cv);

    cv.put("name", "bakri");
    cv.put("lat", 17);
    cv.put("lng", 29);
    newID = db.insert("Demo", null, cv);

    cv.put("name", "geomatics");
    cv.put("lat", 50);
    cv.put("lng", 90);
    newID = db.insert("Demo", null, cv);
    }        

    SQLiteCursor c = (SQLiteCursor) db.rawQuery("SELECT * FROM Demo WHERE lat = 10", null);
    //c.moveToFirst();
    //Toast.makeText(getBaseContext(), c.getCount(), Toast.LENGTH_SHORT).show();
    //dbd.deleteMP(1);   
}   

}

logcat的:

02-27 10:46:35.675: E/AndroidRuntime(25525): FATAL EXCEPTION: main
02-27 10:46:35.675: E/AndroidRuntime(25525): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.androidbook.DBDemo/com.androidbook.DBDemo.DemoData}: android.content.res.Resources$NotFoundException: String resource ID #0x9
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.access$1500(ActivityThread.java:117)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.os.Handler.dispatchMessage(Handler.java:99)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.os.Looper.loop(Looper.java:123)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.main(ActivityThread.java:3691)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at java.lang.reflect.Method.invokeNative(Native Method)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at java.lang.reflect.Method.invoke(Method.java:507)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at dalvik.system.NativeStart.main(Native Method)
02-27 10:46:35.675: E/AndroidRuntime(25525): Caused by: android.content.res.Resources$NotFoundException: String resource ID #0x9
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.content.res.Resources.getText(Resources.java:222)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.widget.Toast.makeText(Toast.java:258)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at com.androidbook.DBDemo.DemoData.onCreate(DemoData.java:54)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615)
02-27 10:46:35.675: E/AndroidRuntime(25525):    ... 11 more

2 个答案:

答案 0 :(得分:1)

问题在于Toast.makeText。 makeText()是一种重载方法,有两种形式 -

makeText(Context c, String s, int duration)

makeText(Context, int resId, int duration)

你正在使用的是第二个(具有resId的那个) - 因为cursor.getCount返回一个整数。现在android正试图找到(在您的Resources类@gen文件夹中)哪个String是附属的cursor.getCount的值。由于它找不到一个,它会抛出一个Resources $ NotFoundException。

修复:代替cursor.getCount(),尝试(String.valueOf(cursor.getCount()))

答案 1 :(得分:0)

它是如何崩溃的?您必须找出错误的详细信息。你能理解你不能准确理解的问题吗?

查看您的logcat详细信息,找出罪魁祸首和错误类型。

机会是:

  • 你要求的时间太长了。在onCreate方法中有一个DB请求并不是一个好主意。此方法在UI线程上执行,并且在5秒不活动后,您的应用程序将因ANR而崩溃。 asynctask会为你提供更好的服务。
  • getBaseContext()看起来很有趣,请使用它。

-------更新-----

您的问题是您将int传递给Toast。然后它期望int表示resourceId。

如果您传递了一个字符串,则不会遇到此问题。使用

 Toast.makeText(getBaseContext(), String.valueOf( c.getCount() ), toast.LENGTH_SHORT).show();