2016-01-20 216 views
1

我的数据库代码如下所示。为什么这些值没有被插入到数据库中?

 public void addprofileinfo(HashMap<String, String> queryValues){ 

     SQLiteDatabase database = this.getWritableDatabase(); 

     ContentValues values = new ContentValues(); 

     values.put("StudentName", queryValues.get("StudentName")); 
     values.put("RegistrationNo", queryValues.get("RegistrationNo")); 
     values.put("Faculty", queryValues.get("Faculty")); 
     values.put("TotalFeePaid", queryValues.get("TotalFeePaid")); 

     database.insert("FEE", null, values); 

     database.close(); 

而且活动代码是: 保护无效的onCreate(捆绑savedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.insertfield); editName =(EditText)findViewById(R.id.editTextName); editFaculty =(EditText)findViewById(R.id.editTextfaculty); editFee =(EditText)findViewById(R.id.editTexttotalfeepaid); editRegid =(EditText)findViewById(R.id.editTextid); save =(Button)findViewById(R.id.buttonsave);

addData(); 
} 

public void addData(){ 
    save.setOnClickListener(new View.OnClickListener() { 

     @Override 
     public void onClick(View arg0) { 
      // TODO Auto-generated method stub 
      try{ 

       HashMap<String, String> queryValuesMap = new HashMap<String, String>(); 

      queryValuesMap.put("StudentName",editName.getText().toString()); 
      queryValuesMap.put("Faculty", editFaculty.getText().toString()); 
      queryValuesMap.put("TotalFee",  editFee.getText().toString()); 
      queryValuesMap.put("RegistrationNo",  editRegid.getText().toString()); 

      dbtools.addprofileinfo(queryValuesMap); 
      Toast.makeText(insertData.this, "Successful!!!", Toast.LENGTH_LONG).show(); 

      Intent intent; 
      intent = new Intent(getApplicationContext(), MainActivity.class); 
      startActivity(intent); 
      dbtools.close(); 
      insertData.this.finish(); 



      }catch(Exception e){ 
       Toast.makeText(insertData.this, e.getMessage(), Toast.LENGTH_LONG).show(); 
      }} 
      }); 

成功保存的消息出现,但该值未在数据库中找到。请说出为什么会发生这种情况?

回答

1

尝试把:

 dbtools.close(); 
     insertData.this.finish(); 

前:

 Intent intent; 
     intent = new Intent(getApplicationContext(), MainActivity.class); 
     startActivity(intent); 
+1

谢谢你很多先生... – Niroj

+1

你能接受这个答案和投票。 –

+1

我做了它,但投票没有被显示。我认为由于我的名誉低。 – Niroj

0
Intent intent; 
     intent = new Intent(getApplicationContext(), MainActivity.class); 
     startActivity(intent); 
     dbtools.close(); 
     insertData.this.finish(); 

该工程..

+1

是的,它的确如此。 @niroj thapa – TechJhola

0

,但它更更好地使用

dbtools.close(); 
    insertData.this.finish(); 
    Intent intent; 
    intent = new Intent(getApplicationContext(), MainActivity.class); 
    startActivity(intent); 

即关闭您的数据库,并启动文件

+0

您的答案都是令人满意的,但我建议您在一个答案中包含所有可能性,以便用户可以在单个答案中找到各种答案。这肯定会有很大的不同。 – TechJhola

相关问题