getReadableDatabase () Исключение нулевого указателя - PullRequest
0 голосов
/ 15 июля 2011

Я ввожу некоторые данные в эту базу данных и затем пытаюсь отобразить эти данные, но я получаю Null Pointer Exception at getReadableDatabase().Основное действие, с которого я ввожу данные, выглядит следующим образом:

public class TabListData extends Activity implements OnClickListener {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        Button b = (Button) findViewById(R.id.enter);
        b.setOnClickListener(this);
        Button b1 = (Button) findViewById(R.id.employeeslist);
        b1.setOnClickListener(this);
    }

    @Override
    public void onClick(View v) {

        EditText name = (EditText) findViewById(R.id.name);
        EditText mobile = (EditText) findViewById(R.id.mobile);

        String nam = name.getText().toString();
        String mob = mobile.getText().toString();

        Button b = (Button) v;
        Button b1 = (Button) v;
         Database d = new Database(getBaseContext());

         switch (b.getId()) {
         case R.id.enter:
             d.input(nam, mob);
         case R.id.employeeslist:
            /* ArrayList<EmployeesResult> results = d.selectEmployees();
                Toast t = Toast.makeText(getBaseContext(), "# records: "
                        + results.size(), 1000);
                t.show();*/
             Intent i = new Intent(this, EmployeesList.class);
            // i.putExtra("Name", "Name");
             startActivity(i);
         }
        }
    }

Это мой класс помощника

public class BaseHelper extends SQLiteOpenHelper {

    public BaseHelper(Context context) {
        super(context, "Employees.db", null, 1);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {

        String createtable = "create table Employee " + "(Name TEXT, " + "Mobile TEXT)";
        db.execSQL(createtable);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub  
    }
}

Это мой класс базы данных.Я использую его для ввода и извлечения данных.Он отлично работал для ввода, когда метода selectEmployees() не было, но теперь он показывает Null Pointer Exception.

public class Database {

    private BaseHelper helper;
    SQLiteDatabase db;
    public Database(Context c){
        helper = new BaseHelper(c); 
    }

    public void input(String Name, String Mobile){
         db = helper.getWritableDatabase();
        try{
        ContentValues values = new ContentValues();
        values.put("Mobile", Mobile);
        values.put("Name", Name);
        db.insert("Employee", "", values);
        Log.e("ENTERED", "ENTERED   "+values);
        }finally {
            if (db != null)
                db.close();
        }
    }
    public ArrayList<EmployeesResult> selectEmployees() {

         db = helper.getReadableDatabase();
        try{
        ArrayList<EmployeesResult> results = new ArrayList<EmployeesResult>();
         Cursor c = db.rawQuery("select * from Employee", null);

         if (c.getCount() > 0) {
                c.moveToFirst();
                do {
                    results.add(new EmployeesResult(
                            c.getString(c.getColumnIndex("Name"))));
                            //c.getInt(c.getColumnIndex("Mobile"))));
                }while(c.moveToNext());
         }
        return results;
    }finally {
        if (db != null)
            db.close();
    }
    }
}

Класс EmployeeResult:

public class EmployeesResult {
    public EmployeesResult(String Name){
        name = Name;
        //mobile = Mobile;  
    }
    public String name;
    public int mobile;
}

Logcat

07-15 23:44:11.008: ERROR/AndroidRuntime(292): FATAL EXCEPTION: main
07-15 23:44:11.008: ERROR/AndroidRuntime(292): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.TabListData/com.TabListData.EmployeesList}: java.lang.NullPointerException
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.app.ActivityThread.access$2300(ActivityThread.java:125)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.os.Handler.dispatchMessage(Handler.java:99)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.os.Looper.loop(Looper.java:123)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.app.ActivityThread.main(ActivityThread.java:4627)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at java.lang.reflect.Method.invokeNative(Native Method)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at java.lang.reflect.Method.invoke(Method.java:521)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at dalvik.system.NativeStart.main(Native Method)
07-15 23:44:11.008: ERROR/AndroidRuntime(292): Caused by: java.lang.NullPointerException
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:98)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.database.sqlite.SQLiteOpenHelper.getReadableDatabase(SQLiteOpenHelper.java:158)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at com.TabListData.Database.selectEmployees(Database.java:35)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at com.TabListData.EmployeesList.onCreate(EmployeesList.java:30)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
07-15 23:44:11.008: ERROR/AndroidRuntime(292):     ... 11 more

Ответы [ 2 ]

1 голос
/ 03 ноября 2013

Ошибка может быть вызвана нулевым указателем в контексте

public class SqLite extends SQLiteOpenHelper {
    public SqLite(Context context, String table, boolean readOnly) {
        super(context, DB_NAME, null, 1);
        getReadableDatabase();    
1 голос
/ 19 июля 2011

Моя проблема решена. Я обнаружил, что проблема именно в проблеме с ListActivity и EmployeeResult.

Для ListActivity возьмите макет XML, содержащий только текст, для отображения текста в ListView. Вот так

<?xml version="1.0" encoding="UTF-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"    
android:layout_width="fill_parent"    
android:layout_height="fill_parent"    
android:padding="10dp"    
android:textSize="16sp" >
</TextView>

и в ListActivity вам просто нужно установить ListAdapter

, например, в методе onCreate ()

List<String> data = dh.SelectStudent();
setListAdapter(new ArrayAdapter<String>(ListofStudents.this, R.layout.text, data));

, а в классе EmployeesResult вместо String используются ArrayAdapter и List

* 1012.* метод в классе DataBase должен быть
public ArrayList<String> SelectStudent() {
    SQLiteDatabase db = _dbHelper.getReadableDatabase();
    try {
        ArrayList<String> results = new ArrayList<String>();
        Cursor c = db.rawQuery("select * from Student", null);
        if (c.getCount() > 0) {
            c.moveToFirst();
            do {
                results.add(c.getString(1));
               // results.add(c.getString(4));

            } while (c.moveToNext());
        }
        return results;
    } finally {
        if (db != null)
            db.close();
    }
}

Я передал String в List и ArrayAdepter, если вам нужно более одной строки, такой как Name и номер мобильного телефона, или комбинацию String и Image в элементе в ListВ этом случае вам нужно создать отдельный класс, в котором у вас есть изображения и строка, и вам нужно передать этот класс вместо String в List и ArrayAdepter.

THANX

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