0

I'm trying to learn basic SQLite in Android. I have created a "Contacts Manager" app in Android Studio 3.0. But when I run it, and whenever I tap a button to insert the data into the SQLite database, it shows a "Unfortunately Contacts Manager has stopped" error.

Here is the code for DatabaseHelper.java:

package com.abdulbasitmehtab.contactsmanager;

import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class DatabaseHelper extends SQLiteOpenHelper {

private static final String DATABASE_NAME = "contacts.db";
private static final String TABLE_NAME = "contacts";

public DatabaseHelper(Context context) {
    super(context, DATABASE_NAME, null, 1);
}

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

}

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

public boolean insertData(String name, int mobile_number, String email){
    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues contentValues = new ContentValues();
    contentValues.put("NAME", name);
    contentValues.put("MOBILE_NUMBER", mobile_number);
    contentValues.put("EMAIL", email);

    long result = db.insert(TABLE_NAME, null, contentValues);
    if(result == -1) 
        return false;

    else 
        return true;

}
}

And the code for MainActivity.java:

package com.abdulbasitmehtab.contactsmanager;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

DatabaseHelper dbHelper;
Button insert;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    dbHelper = new DatabaseHelper(this);

    insert = (Button) findViewById(R.id.btnAdd);

    insert.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Intent intent = new Intent(MainActivity.this, AddNewContact.class);
            startActivity(intent);
        }
    });
}
}

And the code for AddNewContact.java:

package com.abdulbasitmehtab.contactsmanager;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class AddNewContact extends AppCompatActivity {

EditText name, mobile_number, email;
Button save;

private DatabaseHelper databaseHelper;

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

    databaseHelper = new DatabaseHelper(this);
    save = (Button) findViewById(R.id.btnSave);

    save.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            boolean result = databaseHelper.insertData(name.getText().toString(), Integer.parseInt(mobile_number.getText().toString()), email.getText().toString());
            if(result)
                Toast.makeText(AddNewContact.this, "Data Inserted", Toast.LENGTH_LONG).show();

            else
                Toast.makeText(AddNewContact.this, "Data Not Inserted", Toast.LENGTH_LONG).show();

        }
    });
}
}

And the LogCat output is:

02-15 23:54:10.179 3073-3086/com.abdulbasitmehtab.contactsmanager D/EGL_emulation: eglMakeCurrent: 0xae3e4420: ver 2 0 (tinfo 0xae3d28b0)
02-15 23:54:10.194 3073-3086/com.abdulbasitmehtab.contactsmanager D/EGL_emulation: eglMakeCurrent: 0xae3e4420: ver 2 0 (tinfo 0xae3d28b0)
02-15 23:54:10.640 3073-3073/com.abdulbasitmehtab.contactsmanager I/Choreographer: Skipped 35 frames!  The application may be doing too much work on its main thread.
02-15 23:54:10.660 3073-3086/com.abdulbasitmehtab.contactsmanager D/EGL_emulation: eglMakeCurrent: 0xae3e4420: ver 2 0 (tinfo 0xae3d28b0)
02-15 23:54:11.151 3073-3086/com.abdulbasitmehtab.contactsmanager D/EGL_emulation: eglMakeCurrent: 0xae3e4420: ver 2 0 (tinfo 0xae3d28b0)
02-15 23:54:11.375 3073-3073/com.abdulbasitmehtab.contactsmanager I/Choreographer: Skipped 43 frames!  The application may be doing too much work on its main thread.
02-15 23:54:11.512 3073-3086/com.abdulbasitmehtab.contactsmanager D/EGL_emulation: eglMakeCurrent: 0xae3e4420: ver 2 0 (tinfo 0xae3d28b0)
02-15 23:54:11.648 3073-3086/com.abdulbasitmehtab.contactsmanager E/Surface: getSlotFromBufferLocked: unknown buffer: 0xaab0a780
02-15 23:54:25.934 3073-3073/com.abdulbasitmehtab.contactsmanager D/AndroidRuntime: Shutting down VM
02-15 23:54:25.935 3073-3073/com.abdulbasitmehtab.contactsmanager E/AndroidRuntime: FATAL EXCEPTION: main
                                                                                Process: com.abdulbasitmehtab.contactsmanager, PID: 3073
                                                                                java.lang.NullPointerException: Attempt to invoke virtual method 'android.text.Editable android.widget.EditText.getText()' on a null object reference
                                                                                    at com.abdulbasitmehtab.contactsmanager.AddNewContact$1.onClick(AddNewContact.java:28)
                                                                                    at android.view.View.performClick(View.java:5198)
                                                                                    at android.view.View$PerformClick.run(View.java:21147)
                                                                                    at android.os.Handler.handleCallback(Handler.java:739)
                                                                                    at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                                    at android.os.Looper.loop(Looper.java:148)
                                                                                    at android.app.ActivityThread.main(ActivityThread.java:5417)
                                                                                    at java.lang.reflect.Method.invoke(Native Method)
                                                                                    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                                                                                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

0 Answers0