SQLiteOpenHelper.getWriteableDatabase () исключение нулевого указателя на Android - PullRequest
10 голосов
/ 16 ноября 2009

Мне повезло, используя SQLite с прямым, прямым SQL в Android, но я впервые оборачиваю БД в ContentProvider. Я продолжаю получать исключение нулевого указателя при вызове getWritableDatabase() или getReadableDatabase(). Это просто глупая ошибка, которую я сделал с инициализацией в моем коде, или есть большая проблема?

public class DatabaseProvider extends ContentProvider {
  ...
  private DatabaseHelper                   databaseHelper;
  private SQLiteDatabase                   db;
  ...
  @Override
  public boolean onCreate() {
    databaseHelper = new DatabaseProvider.DatabaseHelper(getContext());
    return (databaseHelper == null) ? false : true;
  }
  ...
  @Override
  public Uri insert(Uri uri, ContentValues values) {   
    db = databaseHelper.getWritableDatabase(); // NULL POINTER EXCEPTION HERE
    ...
  }
  private static class DatabaseHelper extends SQLiteOpenHelper {
    public static final String DATABASE_NAME = "cogsurv.db";
    public static final int DATABASE_VERSION = 1;

    public static final String[] TABLES = {
      "people", 
      "travel_logs", 
      "travel_fixes",
      "landmarks", 
      "landmark_visits",
      "direction_distance_estimates" 
    };

    // people._id does not AUTOINCREMENT, because it's set based on server's people.id
    public static final String[] CREATE_TABLE_SQL = {
      "CREATE TABLE people (_id INTEGER PRIMARY KEY," + 
                 "server_id INTEGER," +
                 "name VARCHAR(255)," +
                 "email_address VARCHAR(255))",
      "CREATE TABLE travel_logs (_id INTEGER PRIMARY KEY AUTOINCREMENT," +
                                "server_id INTEGER," +
                                "person_local_id INTEGER," +
                                "person_server_id INTEGER," +
                                "start DATE," +
                                "stop DATE," +
                                "type VARCHAR(15)," +
                                "uploaded VARCHAR(1))",
      "CREATE TABLE travel_fixes (_id INTEGER PRIMARY KEY AUTOINCREMENT," +
                                 "datetime DATE, " +
                                 "latitude DOUBLE, " +
                                 "longitude DOUBLE, " +
                                 "altitude DOUBLE," +
                                 "speed DOUBLE," +
                                 "accuracy DOUBLE," +
                                 "travel_mode VARCHAR(50), " +
                                 "person_local_id INTEGER," +
                                 "person_server_id INTEGER," +
                                 "travel_log_local_id INTEGER," +
                                 "travel_log_server_id INTEGER," +
                                 "uploaded VARCHAR(1))",
      "CREATE TABLE landmarks (_id INTEGER PRIMARY KEY AUTOINCREMENT," +
                              "server_id INTEGER," +
                              "name VARCHAR(150)," +
                              "latitude DOUBLE," +
                              "longitude DOUBLE," +
                              "person_local_id INTEGER," +
                              "person_server_id INTEGER," +
                              "uploaded VARCHAR(1))",
      "CREATE TABLE landmark_visits (_id INTEGER PRIMARY KEY AUTOINCREMENT," +
                                    "server_id INTEGER," +
                                    "person_local_id INTEGER," +
                                    "person_server_id INTEGER," +
                                    "landmark_local_id INTEGER," +
                                    "landmark_server_id INTEGER," +
                                    "travel_log_local_id INTEGER," +
                                    "travel_log_server_id INTEGER," +
                                    "datetime DATE," +
                                    "number_of_questions_asked INTEGER," +
                                    "uploaded VARCHAR(1))",
      "CREATE TABLE direction_distance_estimates (_id INTEGER PRIMARY KEY AUTOINCREMENT," +
                                                 "server_id INTEGER," +
                                                 "person_local_id INTEGER," +
                                                 "person_server_id INTEGER," +
                                                 "travel_log_local_id INTEGER," +
                                                 "travel_log_server_id INTEGER," +
                                                 "landmark_visit_local_id INTEGER," +
                                                 "landmark_visit_server_id INTEGER," +
                                                 "start_landmark_local_id INTEGER," +
                                                 "start_landmark_server_id INTEGER," +
                                                 "target_landmark_local_id INTEGER," +
                                                 "target_landmark_server_id INTEGER," +
                                                 "datetime DATE," +
                                                 "direction_estimate DOUBLE," +
                                                 "distance_estimate DOUBLE," +
                                                 "uploaded VARCHAR(1))"
    };

    public DatabaseHelper(Context context) {
      super(context, DATABASE_NAME, null, DATABASE_VERSION);
      Log.v(Constants.TAG, "DatabaseHelper()");
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
      Log.v(Constants.TAG, "DatabaseHelper.onCreate() starting");

      // create the tables
      int length = CREATE_TABLE_SQL.length;
      for (int i = 0; i < length; i++) {
        db.execSQL(CREATE_TABLE_SQL[i]);
      }
      Log.v(Constants.TAG, "DatabaseHelper.onCreate() finished");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
      for (String tableName : TABLES) {
        db.execSQL("DROP TABLE IF EXISTS" + tableName);
      }
      onCreate(db);
    }
  }
}

Как всегда, спасибо за помощь!

-

Не уверен, что эта деталь поможет, но вот LogCat показывает исключение:

удалена мертвая ссылка ImageShack

Ответы [ 7 ]

6 голосов
/ 16 ноября 2009

Вместо:

databaseHelper = new DatabaseProvider.DatabaseHelper(getContext());

попробовать:

databaseHelper = new DatabaseProvider.DatabaseHelper(this);

и посмотрим, поможет ли это.

Если это не так, не могли бы вы опубликовать NullPointerException трассировку стека?

2 голосов
/ 12 июня 2012

У меня просто была эта проблема с исключением nullpointerexception SQLite, и проблема заключалась в том, что он имел недопустимый контекст.

Мое исправление передавало контекст в onCreate вместо конструктора. Попробуйте найти контекст из другого места, чтобы сделать getApplicationContext().

2 голосов
/ 12 декабря 2010

Эта ошибка почти наверняка из-за того, что неверный контекст был передан в:

super(context, DATABASE_NAME, null, DATABASE_VERSION);
1 голос
/ 15 ноября 2012

У меня просто была эта проблема, и я понял, что это была красная селедка.

Моя проблема возникла из-за того, как я использовал ContentProvider.

Я фактически обращался к ContentProvider напрямую, а не через ContentResolver. По сути, это простой способ отключиться, если вы новичок в использовании ContentProviders.

Надеюсь, это поможет:)

1 голос
/ 07 сентября 2012

попробуйте использовать getWritableDatabase() через некоторое время после инициализации помощника. вы получили NullPointerException, потому что база данных не была полностью подготовлена и не делайте этого в потоке пользовательского интерфейса, или это может вызвать ANR

0 голосов
/ 30 сентября 2012

Я получил эту же ошибку NullPointerException, когда getReadableDatabase () вызывается внутри query (), потому что я неправильно запрашивал моего контент-провайдера. Я не вижу ничего плохого в том, как вы строите свою базу данных. getContext () должен дать вам соответствующий объект контекста. Однако я бы обратил внимание на то, как вы делаете свои запросы к контент-провайдеру. Вы должны убедиться, что у вас есть действительная ссылка на ваш преобразователь контента (т. Е. Вызывая getContentResolver (). Query (..)) и используете его для выполнения запроса.

0 голосов
/ 07 мая 2010

Убедитесь, что при создании AVD укажите некоторое количество места на SD-карте. У меня была такая же проблема, и это решило ее. Если это не помогает, вы также можете попробовать запустить эмулятор с параметром -wipe-data.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...