为什么我的记录更新会给出空指针异常?

时间:2016-01-23 10:46:26

标签: android sqlite insert-update

enter image description here

我正在创建记事本应用程序,并希望更新我的笔记,但我无法在sqlite数据库中记录。请检查我的更新查询 我正在分享错误详情。

public class MainUpdateActivity extends Activity  { 

SQLiteDatabase mydb1;
EditText titleedit,notetextedit;
Button update;


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

        titleedit=(EditText)findViewById(R.id.title);
        notetextedit=(EditText)findViewById(R.id.notetext);
        update=(Button) findViewById(R.id.update);

        Intent myintent = getIntent();

        String product7 = myintent.getStringExtra("product1");
        String product8 = myintent.getStringExtra("product");

        titleedit.setText(product7);
          notetextedit.setText(product8);

update.setOnClickListener(new View.OnClickListener()
            {

            public void onClick(View v)
            {
mydb1.execSQL("UPDATE notes SET (title,notetext) values(?,?);",new String[]{titleedit.getText().toString(),notetextedit.getText().toString()});

Toast.makeText(getApplicationContext(), "note Updated", 3000).show();



            Intent myIntent1 = new Intent(MainUpdateActivity.this,menu.class);

            startActivity(myIntent1);

            finish();

            }

            });

2 个答案:

答案 0 :(得分:4)

您已声明SQLiteDatabase mydb1但未初始化它。错误在这一行。

mydb1.execSQL("UPDATE notes SET (title,notetext) values(?,?);",new String[]{titleedit.getText().toString(),notetextedit.getText().toString()});

您需要初始化mydb1

答案 1 :(得分:2)

看起来像

mydb1.execSQL("UPDATE notes SET (title,notetext) values(?,?);",new String[]{titleedit.getText().toString(),notetextedit.getText().toString()});

mydb1为空,您没有新的并且初始化mydb1