我正在创建记事本应用程序,并希望更新我的笔记,但我无法在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();
}
});
答案 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
。