Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/209.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android Can';t打开SQLite数据库_Android - Fatal编程技术网

Android Can';t打开SQLite数据库

Android Can';t打开SQLite数据库,android,Android,我正在尝试使用以下命令来编写SQLite db: dbHelper = new DataBaseHelper(context); public static void open() throws SQLException { try { database = dbHelper.getWritableDatabase(); } catch (Exception e) { e.printStackTrace(); Log.d(Tag.g

我正在尝试使用以下命令来编写SQLite db:

dbHelper = new DataBaseHelper(context);
public static void open() throws SQLException {
    try {
        database = dbHelper.getWritableDatabase();
    } catch (Exception e) {
        e.printStackTrace();
        Log.d(Tag.getTag("open()"), "Can't open db");
    }
}
但它给出了
NullPointerException
。下面是我的
DataBaseHelper

//declarations and stuff

public DataBaseHelper(Context context) {
    super(context, VFS_DATABASE_NAME, null, DATABASE_VERSION);
    this.context = context;
}

@Override
public void onCreate(SQLiteDatabase db) {
    // TODO Auto-generated method stub
    Toast.makeText(context, "Creating DataBase for first time...", 2000).show();
    db.execSQL(DATABASE_CREATE);

}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    Log.w(DataBaseHelper.class.getName(),
            "Upgrading database from version " + oldVersion + " to "
                    + newVersion + ", which will destroy all old data");
    db.execSQL("DROP TABLE IF EXISTS" + VFS_DATABASE_TABLE);
    onCreate(db);

}
我不知道我做错了什么。为什么会发生这种错误

堆栈跟踪:

02-27 23:16:07.698: W/System.err(4685): java.lang.NullPointerException
02-27 23:16:07.698: W/System.err(4685):     at com.manager.boot.r1223.VSDataSource.open(VSDataSource.java:34)
02-27 23:16:07.698: W/System.err(4685):     at com.manager.boot.r1223.VSDataSource.ScanVirtualSystems(VSDataSource.java:52)
02-27 23:16:07.706: W/System.err(4685):     at com.manager.boot.r1223.OSListActivity.onCreate(OSListActivity.java:49)
02-27 23:16:07.706: W/System.err(4685):     at android.app.Activity.performCreate(Activity.java:4465)
02-27 23:16:07.706: W/System.err(4685):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
02-27 23:16:07.706: W/System.err(4685):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
02-27 23:16:07.706: W/System.err(4685):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
02-27 23:16:07.706: W/System.err(4685):     at android.app.ActivityThread.access$600(ActivityThread.java:123)
02-27 23:16:07.706: W/System.err(4685):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
02-27 23:16:07.706: W/System.err(4685):     at android.os.Handler.dispatchMessage(Handler.java:99)
02-27 23:16:07.706: W/System.err(4685):     at android.os.Looper.loop(Looper.java:137)
02-27 23:16:07.706: W/System.err(4685):     at android.app.ActivityThread.main(ActivityThread.java:4424)
02-27 23:16:07.706: W/System.err(4685):     at java.lang.reflect.Method.invokeNative(Native Method)
02-27 23:16:07.706: W/System.err(4685):     at java.lang.reflect.Method.invoke(Method.java:511)
02-27 23:16:07.706: W/System.err(4685):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
02-27 23:16:07.706: W/System.err(4685):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
02-27 23:16:07.706: W/System.err(4685):     at dalvik.system.NativeStart.main(Native Method)

我认为问题是静态的。试着不用它

我的例子是:

public class MyActivity extends ListActivity {

   private DatabaseHandler db;

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

    db = new DatabaseHandler(this);
    ...
}

添加从
Logcat
获得的异常后得到的异常的堆栈跟踪。dbhelper是静态的吗?如果不是,那就是你的问题。@AedonEtLIRA你是说像
publicstaticdatabasehelper(Context-Context){super…}
static?不,我想你有设计问题。如果要从各种活动访问数据库,请创建一个封装数据库的类(并且仅通过该类公开数据库),并在计划访问数据库的每个类中创建数据库的对象。如果我将其删除,则无法从活动类中调用它。因此无法测试。您的活动也是静态的吗?如何创建数据库?execSQL(创建数据库);您可以发布这个字符串吗?execsql
“如果不存在创建表”+VFS\u DATABASE\u TABLE+”(“+BaseColumns.\u ID+”INTEGER主键自动递增“+VIRTUAL\u-SYSTEM\u-COLUMN\u-NAME+”VARCHAR(50),“+VIRTUAL\u-SYSTEM\u-COLUMN\u-PATH+”VARCHAR(50),“+VIRTUAL\u-SYSTEM\u-COLUMN\u-TYPE+”INTEGER,“+VIRTUAL\u SYSTEM\u COLUMN\u DESCRIPTION+“VARCHAR(200))”
也许问题出在您的设计中,就像@slukian所说的那样。如何声明数据库处理程序?我的是“公共类DatabaseHandler扩展SQLiteOpenHelper”。