[英]getWritableDatabase() causing nullPointerException
I want to open my database with SQLite. 我想用SQLite打开数据库。 But when attempting to take data from a TextInputEditText and put it into the database it throws NPE at db = this.getWritableDatabase();
但是,当尝试从TextInputEditText提取数据并将其放入数据库时,会在db = this.getWritableDatabase();
处抛出NPE db = this.getWritableDatabase();
Seems that most of the time this is caused by the context
being null. 似乎大多数情况下,这是由context
为空引起的。 But it is not null and I checked it with debugger. 但这不是null,我使用调试器进行了检查。 ( myDB = new DatabaseHelper(this);
) ( myDB = new DatabaseHelper(this);
)
(I have tried all other questions about this problem and my situation must be different because they did not help.) (我已经尝试过所有其他有关此问题的问题,并且我的情况必须有所不同,因为它们没有帮助。)
MainActivity.java 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 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;
}
}
}
Exception 例外
12-06 23:39:12.799 26304-26304/com.example.ryan.temporaryname E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.ryan.temporaryname, PID: 26304 java.lang.NullPointerException: Attempt to invoke virtual method 'long android.database.sqlite.SQLiteDatabase.insert(java.lang.String, java.lang.String, android.content.ContentValues)' on a null object reference at com.example.ryan.temporaryname.DatabaseHelper.insertData(DatabaseHelper.java:45) at com.example.ryan.temporaryname.MainActivity$1.onClick(MainActivity.java:64) at android.view.View.performClick(View.java:6294) at android.view.View$PerformClick.run(View.java:24770) at android.os.Handler.handleCallback(Handler.java:790) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:164) at android.app.ActivityThread.main(ActivityThread.java:6494) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438) at com.android.in 12-06 23:39:12.799 26304-26304 / com.example.ryan.temporaryname E / AndroidRuntime:致命例外:主进程:com.example.ryan.temporaryname,PID:26304 java.lang.NullPointerException:尝试调用虚拟com.example.ryan.temporaryname.DatabaseHelper.insertData()上的空对象引用上的方法'long android.database.sqlite.SQLiteDatabase.insert(java.lang.String,java.lang.String,android.content.ContentValues)' com.example.ryan.temporaryname.MainActivity $ 1.onClick(MainActivity.java:64)的android.view.View.performClick(View.java:6294)的android.view.View $ PerformClick的DatabaseHelper.java:45)。在android.os.Looper.loop(Looper.java)上运行(View.java:24770)在android.os.Handler.handleCallback(Handler.java:790)在android.os.Handler.dispatchMessage(Handler.java:99) :164),位于android.app.ActivityThread.main(ActivityThread.java:6494),位于com.android.internal.os.RuntimeInit $ MethodAndArgsCaller.run(RuntimeInit.java)的java.lang.reflect.Method.invoke(本机方法) :438),位于com.android.in ternal.os.ZygoteInit.main(ZygoteInit.java:807) ternal.os.ZygoteInit.main(ZygoteInit.java:807)
我认为你应该(如果这不是一个测试sqlite应用程序)通过创建一个App()类来创建一个单例并在那里初始化数据库。尝试也解决你的问题
I think the problem is about TABLE_NAME - "login_table.db" suggests a table named "db" in a database named "login_table", which does not exist, and a null database object is returned. 我认为问题与TABLE_NAME有关-“ login_table.db”建议在名为“ login_table”的数据库中存在一个名为“ db”的表,该表不存在,并且返回空数据库对象。
Please try to change the name. 请尝试更改名称。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.