没有这样的表异常SQLite

时间:2013-03-04 20:58:27

标签: android sqlite

我的代码现在如下:

主应用程序java:

    String TAG = "DATABASES";    
    try {

        String destPath = "/data/data/" + getPackageName()
                + "/databases/data.db";

        File f = new File(destPath);
        if(!f.exists()){
            Log.v(TAG,"Dest DB doesn't exist");
            InputStream in = getAssets().open("airports.db");
            OutputStream out = new FileOutputStream(destPath);

            byte[] buffer = new byte[1024];
            int length;
            while ((length = in.read(buffer)) > 0) {
                out.write(buffer, 0, length);
            }
            in.close();
            out.close();
        } else {
            Log.v(TAG,"File exists: " + destPath);  

        }

    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        Log.v(TAG,"ioexeption");
        e.printStackTrace();
    }

    DBManager dbManager =  new DBManager(this);
    Log.v(TAG,"Database is there with version: "+dbManager.getReadableDatabase().getVersion());
    //String sql = "select * from airports where IATA='GRO' ";
    String sql = "select count(*) from airports";


    SQLiteDatabase db = dbManager.getReadableDatabase();
    Cursor cursor = db.rawQuery(sql, null);
    Log.v(TAG,"Query Result:"+cursor);


    cursor.close();
    db.close();
    dbManager.close();

我的DBManager.java:

package com.jammo.mywidget4;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;

public class DBManager extends SQLiteOpenHelper {

private static final int DATABASE_VERSION = 1;
private static final String TAG = "DATABASES";

public DBManager(Context context) {
    super(context, "data.db", null, DATABASE_VERSION);

}

@Override
public void onCreate(SQLiteDatabase db) {
    Log.v(TAG,"On create Called:"+db.getPath());
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}

现在,在启动“db”时,main.java中的执行运行正常,但是在下一行尝试执行rawQuery()时失败

FYI“从机场选择计数(*)”在我的Sqlite DB Manager GUI上运行返回1650行。

错误日志说:

03-04 21:54:24.200: E/AndroidRuntime(11513): FATAL EXCEPTION: main
03-04 21:54:24.200: E/AndroidRuntime(11513): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.jammo.mywidget4/com.jammo.mywidget4.SectorInfo}: android.database.sqlite.SQLiteException: no such table: airports: , while compiling: select count(*) from airports

本地/assets/airports.db“似乎”被检测到并被复制到/data/data/mypackage/databases/data.db作为“找到文件”

非常感谢 Ĵ

1 个答案:

答案 0 :(得分:2)

不使用DBManager类就试一试。

注释掉这一行......

DBManager dbManager =  new DBManager(this);

...然后通过替换此行显式打开数据库...

SQLiteDatabase db = dbManager.getReadableDatabase();

...与...

SQLiteDatabase db = SQLiteDatabase.openDatabase(destPath, null, SQLiteDatabase.OPEN_READONLY);

然后清除应用程序数据,以便从assets目录重新复制数据库。

编辑:即使我的建议有效,但它实际上只是一种解决方法,问题的根源就在于此......

String destPath = "/data/data/" + getPackageName() + "/databases/data.db";

你应该避免使用Android的硬编码路径 - 它们可能适用于许多设备,但不能保证它们可以与所有设备一起使用,甚至不适用于所有版本的Android。

问题是您正在创建/复制数据库到该路径,但DBManager类可能会创建一个位于文件系统中不同路径上的空数据库。

要解决所有设备和Android版本的问题,在复制数据库之前,我会使用...

SQLiteDatabase.openOrCreateDatabase("data.db", null)

...创建一个'虚拟'(空)数据库。然后我打电话给...

getDatabasePath("data.db")

...获取data.db的绝对路径。然后,您可以在复制操作期间覆盖该数据库,从那时起,您可以使用扩展SQLiteOpenHelper的类,它将找到正确的数据库。

相关问题