Android sqlite rowcount总是为零?

时间:2013-03-04 18:56:29

标签: android sqlite

我已经使用GUI创建了一个包含1650条记录的数据库。

我正在尝试查询此数据库,但它总是返回任何内容。我已经尝试编写一个简单的getrowcount()方法来查看我是否得到任何东西,但它总是返回零。如果有人可以帮助指出发生了什么,我必须在这里遗漏一些明显的东西。

在我的主app.java

    db = new DbHandler(this);
    String sIcao1 = "ROW COUNT = " + String.valueOf(db.getRowCount());

在我的dbhandler.java

package com.jammo.mywidget4;

<snip - standard includes>

public class DbHandler extends SQLiteOpenHelper {

    private static SQLiteDatabase db;
    private static final int DATABASE_VERSION = 1;
    private static final String DATABASE_NAME = "airports";
    private static final String TABLE_AIRPORTS = "airports";

    public DbHandler(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);

        db = this.getWritableDatabase();
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db = this.getWritableDatabase();
    }

    int getRowCount() {

        int nCount = -1;
        //SQLiteDatabase db = this.getReadableDatabase();
        Cursor cur = db.rawQuery("SELECT * FROM airports", null);
        nCount = cur.getCount();
        if (cur != null) {
            //cur.moveToFirst();                      
            //nCount = cur.getInt(0);
            //if (cur.getInt (0) == 0) {              

            //}
        }

        return nCount;
    }

}

在GUI(SQLite数据库浏览器)中,我正在做一个简单的

select * from airports

...我正在回到完整的行数。当我调试Java时,游标什么都不返回。

此外,GUI创建的数据库位于myapp/assets/airports.db

有什么想法吗?

1 个答案:

答案 0 :(得分:0)

我认为您需要在DATABASE_NAME中加入.db

尝试更改此内容:

private static final String DATABASE_NAME = "airports";

到此:

private static final String DATABASE_NAME = "airports.db";

修改

实际上我认为即使有这种改变也不适合你。 SQLiteOpenHelper期望你的db文件在/data/data/your.package/databases/内。所以我认为如果你想让它与未经修改的SQLiteOpenHelper一起使用,你需要将它从资产复制到那里。

请点击此处了解如何将其复制:Android: Accessing assets folder sqlite database file with .sqlite extension