我已经使用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
。
有什么想法吗?
答案 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