this.getReadableDatabase()的NullPointerException;

时间:2014-09-03 08:04:18

标签: java android database sqlite nullpointerexception

Heyhey:)

我查看了同一主题的几个问题,但我找不到解决问题的方法。

this.getReadableDatabase();处出现NullPointerException ...

这是我的代码:

public class DatabaseHandler extends SQLiteOpenHelper {

public static final int DATABASE_VERSION = 1;

public static final String DATABASE_NAME = "TODO_APP";

/*--------------------------- TABLE ITEMS START ---------------------------*/
private static final String TABLE_ITEMS = "items";
private static String KEY_ID_ITEMS = "id_items";
private static final String KEY_CATEGORY_ITEMS = "category";
private static final String KEY_DATETIME_ITEMS = "datetime";
private static String KEY_NAME_ITEMS = "name";
private static final String KEY_DESCRIPTION_ITEMS = "description";
private static final String KEY_ALARM_ITEMS = "alarm";

public DatabaseHandler(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

@Override
public void onCreate(SQLiteDatabase db) {

    // create table ITEMS
    String CREATE_ITEMS_TABLE = "CREATE TABLE " + TABLE_ITEMS + "("
            + KEY_ID_ITEMS + " INTEGER PRIMARY KEY," + KEY_CATEGORY_ITEMS
            + " INTEGER," + KEY_DATETIME_ITEMS
            + " TIMESTAMP DEFAULT CURRENT_TIMESTAMP," + KEY_NAME_ITEMS
            + " TEXT," + KEY_DESCRIPTION_ITEMS + " TEXT," + KEY_ALARM_ITEMS
            + " INTEGER" + ");";
    db.execSQL(CREATE_ITEMS_TABLE);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // Drop older table if existed
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_ITEMS);

    // Create tables again
    this.onCreate(db);
}

public void addItem(DB_Item item) {
    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues values = new ContentValues();
    values.put(KEY_CATEGORY_ITEMS, item.getCategory());
    values.put(KEY_NAME_ITEMS, item.getName());
    values.put(KEY_DESCRIPTION_ITEMS, item.getDescription());
    values.put(KEY_ALARM_ITEMS, item.getAlarm());

    // Inserting Row
    db.insert(TABLE_ITEMS, null, values);
    db.close(); // Closing database connection
}

public DB_Item getItem(String name) {

//!!!!! Here is one problem !!!!!
    SQLiteDatabase db = this.getReadableDatabase();

    Cursor cursor = db.query(TABLE_ITEMS, new String[] { KEY_ID_ITEMS,
            KEY_CATEGORY_ITEMS, KEY_DATETIME_ITEMS, KEY_NAME_ITEMS,
            KEY_DESCRIPTION_ITEMS, KEY_ALARM_ITEMS },
            KEY_NAME_ITEMS = " = ?", new String[] { String.valueOf(name) },
            null, null, null, null);
    if (cursor != null) {
        cursor.moveToFirst();
    }

    // DB_Item (int category, String name, String description, int
    // alarm)
    DB_Item item = new DB_Item(cursor.getInt(1), cursor.getString(3),
            cursor.getString(4), cursor.getInt(5));

    return item;
}

public List<DB_Item> getAllItems() {
    List<DB_Item> itemList = new ArrayList<DB_Item>();

    // SELECT ALL
    String selectQuery = "SELECT * FROM " + TABLE_ITEMS;

//!!!!!!!!!! here is the other Problem
    SQLiteDatabase database = this.getWritableDatabase();

    Cursor cursor = database.rawQuery(selectQuery, null);

    // go through all rows and then adding to list
    if (cursor.moveToFirst()) {
        do {
            DB_Item item = new DB_Item();
            item.setCategory(Integer.parseInt(cursor.getString(0)));
            // TODO

            // adding to list
            itemList.add(item);
        } while (cursor.moveToNext());
    }
    return itemList;
}

[等等,没有复制整个代码]

希望你能帮助我...... 该错误肯定出现在SQLiteDatabase db = this.getReadableDatabase();

输出:

09-03 08:34:17.863: E/AndroidRuntime(7074): java.lang.RuntimeException: Unable to start activity ComponentInfo{todo.todo_list/todo.view.StartApp}: java.lang.NullPointerException
09-03 08:34:17.863: E/AndroidRuntime(7074):     at todo.database.DatabaseHandler.getAllItems(DatabaseHandler.java:144)
09-03 08:34:17.863: E/AndroidRuntime(7074):     at todo.helper.SortItems.sortItemsCategory(SortItems.java:16)
09-03 08:34:17.863: E/AndroidRuntime(7074):     at todo.view.StartApp.onCreate(StartApp.java:36)

2 个答案:

答案 0 :(得分:1)

将您的班级更改为以下内容:

package com.mhp.example;

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

public class DBAdapter {
/*--------------------------- TABLE ITEMS START ---------------------------*/
private static final String TABLE_ITEMS = "items";
private static String KEY_ID_ITEMS = "id_items";
private static final String KEY_CATEGORY_ITEMS = "category";
private static final String KEY_DATETIME_ITEMS = "datetime";
private static String KEY_NAME_ITEMS = "name";
private static final String KEY_DESCRIPTION_ITEMS = "description";
private static final String KEY_ALARM_ITEMS = "alarm";


private static final String TAG = "DBAdapter";

private static final String DATABASE_NAME = "dbname";
private static final int DATABASE_VERSION = 1;

tring CREATE_ITEMS_TABLE = "CREATE TABLE " + TABLE_ITEMS + "("
        + KEY_ID_ITEMS + " INTEGER PRIMARY KEY," + KEY_CATEGORY_ITEMS
        + " INTEGER," + KEY_DATETIME_ITEMS
        + " TIMESTAMP DEFAULT CURRENT_TIMESTAMP," + KEY_NAME_ITEMS
        + " TEXT," + KEY_DESCRIPTION_ITEMS + " TEXT," + KEY_ALARM_ITEMS
        + " INTEGER" + ");";





private final Context context;    

private DatabaseHelper DBHelper;
private SQLiteDatabase db;

public DBAdapter(Context ctx) 
{
    this.context = ctx;
    DBHelper = new DatabaseHelper(context);
}

private static class DatabaseHelper extends SQLiteOpenHelper 
{
    DatabaseHelper(Context context) 
    {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) 
    {
        try {
            db.execSQL(CREATE_ITEMS_TABLE); 
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

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

        onCreate(db);
    }
}    

//---opens the database---
public DBAdapter open() throws SQLException 
{
    db = DBHelper.getWritableDatabase();
    return this;
}

//---closes the database---    
public void close() 
{
    DBHelper.close();
}


public void addItem(DB_Item item) {

ContentValues values = new ContentValues();
values.put(KEY_CATEGORY_ITEMS, item.getCategory());
values.put(KEY_NAME_ITEMS, item.getName());
values.put(KEY_DESCRIPTION_ITEMS, item.getDescription());
values.put(KEY_ALARM_ITEMS, item.getAlarm());

// Inserting Row
db.insert(TABLE_ITEMS, null, values);
}

public DB_Item getItem(String name) {


Cursor cursor = db.query(TABLE_ITEMS, new String[] { KEY_ID_ITEMS,
        KEY_CATEGORY_ITEMS, KEY_DATETIME_ITEMS, KEY_NAME_ITEMS,
        KEY_DESCRIPTION_ITEMS, KEY_ALARM_ITEMS },
        KEY_NAME_ITEMS = " = ?", new String[] { String.valueOf(name) },
        null, null, null, null);
if (cursor != null) {
    cursor.moveToFirst();
}

// DB_Item (int category, String name, String description, int
// alarm)
DB_Item item = new DB_Item(cursor.getInt(1), cursor.getString(3),
        cursor.getString(4), cursor.getInt(5));

return item;
}

public List<DB_Item> getAllItems() {
List<DB_Item> itemList = new ArrayList<DB_Item>();

// SELECT ALL
String selectQuery = "SELECT * FROM " + TABLE_ITEMS;


Cursor cursor = db.rawQuery(selectQuery, null);

// go through all rows and then adding to list
if (cursor.moveToFirst()) {
    do {
        DB_Item item = new DB_Item();
        item.setCategory(Integer.parseInt(cursor.getString(0)));
        // TODO

        // adding to list
        itemList.add(item);
    } while (cursor.moveToNext());
}
return itemList;
}
}  

注意:当你从数据库适配器创建对象时,你应该打开()db并在你的工作结束后()它。

DBAdapter db = new DBAdapter(contex);
db.open();
//do you work
db.close();

答案 1 :(得分:0)

只需使用getReadableDatabase()而不使用this