getWritableDatabase () вызывает nullPointerException - PullRequest
0 голосов
/ 07 декабря 2018

Я хочу открыть свою базу данных с помощью SQLite.Но при попытке взять данные из TextInputEditText и поместить их в базу данных он выбрасывает NPE в db = this.getWritableDatabase();

. Похоже, что в большинстве случаев это вызвано тем, что context равен нулю.Но это не ноль, и я проверил это с помощью отладчика.(myDB = new DatabaseHelper(this);)

(я пробовал все остальные вопросы по этой проблеме, и моя ситуация должна отличаться, потому что они не помогли.)

MainActivity.java

public class MainActivity extends AppCompatActivity {
    DatabaseHelper myDB;
    TextInputEditText inputEmail;
    TextInputEditText inputPass;
    Button btn_login;
    Button btn_signup;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        try {
            myDB = new DatabaseHelper(this);
        } catch (Exception e) {
            System.out.print("Exception occurred");
        }
        btn_signup = findViewById(R.id.btn_signup);
        btn_login = findViewById(R.id.btn_login);
        addData();
    }

    public void addData() {
        btn_signup.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                inputEmail = findViewById(R.id.editTextEmail);
                inputPass = findViewById(R.id.editTextPass);
                //try {
                myDB.insertData(inputEmail.getText().toString(), 
                inputPass.getText().toString());

                Toast.makeText(MainActivity.this, "Data Inserted", 
                Toast.LENGTH_LONG).show();

               // } catch (Exception e) {
               //     e.printStackTrace();
               // }
            }
        });
    }

DatabaseHelper.java

public class DatabaseHelper extends SQLiteOpenHelper {

    public static final String DATABASE_NAME = "Login_android.db";
    public static final String TABLE_NAME = "login_table.db";
    public static final String COL1 = "ID";
    public static final String COL2 = "EMAIL";
    public static final String COL3 = "PASSWORD";


    public DatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, 1);
        //SQLiteDatabase db = this.getWritableDatabase();
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE " + TABLE_NAME +" (ID INTEGER PRIMARY KEY 
        AUTOINCREMENT, EMAIL TEXT, PASSWORD TEXT)");
    }

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

    public boolean insertData(String email, String password) {

        SQLiteDatabase db = null;
        try {
            db = this.getWritableDatabase();
        } catch (Exception e) {
            e.printStackTrace();
        }
        //db.isOpen();
        ContentValues contentValues = new ContentValues();
        contentValues.put(COL2, email);
        contentValues.put(COL3, password);
        long result = db.insert(TABLE_NAME, null, contentValues);
        if (result == -1) {
            return false;
        } else {
            return true;
        }
    }
}

Исключение

12-06 23: 39: 12,79926304-26304 / com.example.ryan.teventname E / AndroidRuntime: ИСКЛЮЧИТЕЛЬНОЕ ИСКЛЮЧЕНИЕ: основной процесс: com.example.ryan.teventname, PID: 26304 java.lang.NullPointerException: попытка вызвать виртуальный метод long android.database.sqlite.SQLiteDatabase.insert (java.lang.String, java.lang.String, android.content.ContentValues) 'для ссылки на пустой объект по адресу com.example.ryan.teilitaryname.DatabaseHelper.insertData (DatabaseHelper.java:45) по адресу com.example.ryan.teventname.MainActivity $ 1.onClick (MainActivity.java:64) на android.view.View.performClick (View.java:6294) на android.view.View $ PerformClick.run (View.java:24770)на android.os.Handler.handleCallback (Handler.java:790) на android.os.Handler.dispatchMessage (Handler.java:99) в android.os.Looper.loop (Looper.java:164) в android.app.ActivityThread.main (ActivityThread.java:6494) в java.lang.reflect.Method.invoke(Собственный метод) в com.android.internal.os.RuntimeInit $ MethodAndArgsCaller.run (RuntimeInit.java:438) в com.android.internal.os.ZygoteInit.main (ZygoteInit.java:807)

Ответы [ 2 ]

0 голосов
/ 07 декабря 2018

Я думаю, что проблема в TABLE_NAME - "login_table.db" предлагает таблицу с именем "db" в базе данных с именем "login_table", которая не существует, и возвращается нулевой объект базы данных.

Пожалуйста, попробуйте изменить имя.

0 голосов
/ 07 декабря 2018

я думаю, вам следует (если это не тестовое приложение sqlite) создать синглтон, создав класс App () и инициализировать там базу данных. Попробуйте также решить вашу проблему

...