0

我不断收到此错误 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>
4

1 回答 1

0

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

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

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

无论如何,请检查您的跟踪 adb logcat以更好地了解代码失败的地方。

于 2012-11-11T12:42:27.400 回答