Android空指针异常和数据库更新

时间:2012-11-11 12:36:58

标签: android android-layout

我一直收到此错误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>

1 个答案:

答案 0 :(得分:0)

我们需要堆栈跟踪来检查错误在哪里。虽然你的OnCreate方法中的constuctor调用MainActivity obj = new MainActivity();看起来很奇怪。据我所知,你不需要调用Activity的构造函数

您可以参考您的活动电话this

尝试删除MainActivity obj = new MainActivity();this.Update(1, "Raza", "17", "Nohting");,也不需要运行openOrCreateDatabase两次,而是在OnCreate和方法上运行它。

在任何情况下,请检查跟踪adb logcat,以便更好地了解代码失败的位置。