myc_100 2013-02-21 01:58 采纳率: 10%
浏览 3080
已采纳

不能打开 SQLite 数据库

我使用下面的代码打开 SQLite 数据库:

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

2条回答

  • hxn_217 2013-02-27 03:02
    关注

    我认为是 static 中的问题,去掉它。
    例如:

    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);
        ...
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)