我一直收到此错误java.null.pointer异常当我试图运行此代码时,请帮助我如何解决此问题并更新我的数据库值。 这是我的代码 主要活动类
package dom.example.database_exp;
import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.view.Menu;
import android.widget.EditText;
public class MainActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
MainActivity obj = new MainActivity();
SQLiteDatabase db =openOrCreateDatabase("Test", MODE_PRIVATE, null);
obj.Update(1, "Raza", "17", "Nohting");
Cursor c = db.rawQuery("SELECT FirstName FROM test WHERE ID = 1 ",null);
c.moveToFirst();
EditText dis=(EditText)findViewById(R.id.editText1);
String result = c.getString(c.getColumnIndex("FirstName"));
dis.setText("You have found "+result);
db.close();
/** EditText dis=(EditText)findViewById(R.id.editText1);
//Creating and opening the database
SQLiteDatabase db=openOrCreateDatabase("RamDB", MODE_PRIVATE,null);
//Creating table with 3 columns
db.execSQL("CREATE TABLE IF NOT EXISTS Test(ID INTEGER PK NOT NULL FirstName VARCHAR,LastName VARCHAR,Age INT(3));");
**/
}
public int Update (int sid, String name, String age, String course)
{
String FirstName = "FirstName";
String LastName = "LastName";
String test = "test";
String ID = "ID";
// String _id = "1" ;
SQLiteDatabase db =openOrCreateDatabase("Test", MODE_PRIVATE, null);
ContentValues pau = new ContentValues();
pau.put(FirstName, name);
return db.update(test, pau,ID + "=" + sid, null);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
我的xml文件
<EditText
android:id="@+id/editText1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginLeft="51dp"
android:layout_marginTop="89dp"
android:ems="10"
android:inputType="text" >
<requestFocus />
</EditText>
</RelativeLayout>
答案 0 :(得分:0)
我们需要堆栈跟踪来检查错误在哪里。虽然你的OnCreate方法中的constuctor调用MainActivity obj = new MainActivity();
看起来很奇怪。据我所知,你不需要调用Activity的构造函数
您可以参考您的活动电话this
尝试删除MainActivity obj = new MainActivity();
和this.Update(1, "Raza", "17", "Nohting");
,也不需要运行openOrCreateDatabase两次,而是在OnCreate和方法上运行它。
在任何情况下,请检查跟踪adb logcat
,以便更好地了解代码失败的位置。