2013-09-06 4 views
0

и хороший день. Мой проект имеет 2 действия, первый для вставки данных в базу данных, которая работает хорошо, но затем я хочу показать представление списка данных в базе данных в другой деятельности.Использование listviews с базой данных

Я пробовал локальные данные, например, fred, george в массиве, и представление списка отлично работает, однако, когда я пытаюсь использовать базу данных. Сбой активности. Кажется, что я не могу использовать «database.open»

public class MyListActivity extends Activity{ 

    DatabaseAdapter database; 

    //Creates item_details based on the ListItemDetails class 
    ListItemDetails item_details; 

    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_list); 

     //Uses the arraylist and set the result 
     ArrayList<ListItemDetails> result = GetSearchResults(); 

     ListView lv = (ListView)findViewById(R.id.listView1); 
     lv.setAdapter(new CustomListAdapter(getApplicationContext(),result)); 

    } 

    private ArrayList<ListItemDetails> GetSearchResults() { 
     ArrayList<ListItemDetails> results = new ArrayList<ListItemDetails>(); 

     item_details = new ListItemDetails(); 

     /* 
     database.open(); 
     Cursor c = database.getAllContacts(); 
     if (c.moveToFirst()) 
     { 
      do { 
       item_details.setFirstName(c.getString(1)); 
       results.add(item_details); 
      } while (c.moveToNext()); 
     }   
     */ 
     return results; 
    } 

} 

Главное здесь. База данных открывается отлично, когда я использую кнопку buttonShow, поэтому я попробовал buttonTest и сохранил их в списке, но для меня это немного запутывало.

public class FamousPersonActivity extends Activity { 

    EditText editFirstName, editLastName; 
    Button buttonAdd, buttonShow, buttonTest; 

    ListView lv; 
    ListItemDetails item_details; 
    DatabaseAdapter database; 
    int request_Code = 1; 

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

     database = new DatabaseAdapter(this); 


     lv = (ListView)findViewById(R.id.listView1); 
     //ArrayList<ListItemDetails> result = GetSearchResults(); 
     //lv.setAdapter(new CustomListAdapter(getApplicationContext(),result)); 
     editFirstName = (EditText)findViewById(R.id.editFirstName); 
     editLastName = (EditText)findViewById(R.id.editLastName); 
     buttonAdd = (Button)findViewById(R.id.buttonAdd); 
     buttonShow = (Button)findViewById(R.id.buttonShow); 
     buttonTest = (Button)findViewById(R.id.buttonTest); 

     buttonAdd.setOnClickListener(new View.OnClickListener() { 

      @Override 
      public void onClick(View arg0) { 
       Toast.makeText(getApplicationContext(), "added to database", Toast.LENGTH_SHORT).show(); 

       database.open(); 
       long id = database.insertContact("Test Contact", "Test Email") ; 
       database.close(); 
      } 
     }); 

     buttonTest.setOnClickListener(new View.OnClickListener() { 

      @Override 
      public void onClick(View v) { 


       Intent i = new Intent("com.id11020260.exercise6part2.MyListActivity"); 
       startActivityForResult(i, request_Code); 

      } 
     }); 

     buttonShow.setOnClickListener(new View.OnClickListener() { 

      @Override 
      public void onClick(View arg0) { 

       try { 
        String destPath = "/data/data/" + getPackageName() + 
         "/databases"; 
        File f = new File(destPath); 
        if (!f.exists()) {    
         f.mkdirs(); 
         f.createNewFile(); 

         //---copy the db from the assets folder into 
         // the databases folder--- 
         CopyDB(getBaseContext().getAssets().open("mydb"), 
          new FileOutputStream(destPath + "/MyDB")); 
        } 
       } catch (FileNotFoundException e) { 
        e.printStackTrace(); 
       } catch (IOException e) { 
        e.printStackTrace(); 
       } 

       //---get all contacts--- 
       database.open(); 
       Cursor c = database.getAllContacts(); 
       if (c.moveToFirst()) 
       { 
        do { 
         DisplayContact(c); 
        } while (c.moveToNext()); 
       } 

       database.close(); 
      } 

      }); 

     } 

    private ArrayList<ListItemDetails> GetSearchResults() { 

     ArrayList<ListItemDetails> results = new ArrayList<ListItemDetails>(); 

     item_details = new ListItemDetails(); 

     database.open(); 
     Cursor c = database.getAllContacts(); 

     if (c.moveToFirst()) 
     { 
      do { 
       item_details.setFirstName(c.getString(1)); 
       results.add(item_details); 
      } while (c.moveToNext()); 
      database.close(); 
     } 
     return results; 
    } 

    public void CopyDB(InputStream inputStream, 
    OutputStream outputStream) throws IOException { 
    //---copy 1K bytes at a time--- 
    byte[] buffer = new byte[1024]; 
    int length; 
    while ((length = inputStream.read(buffer)) > 0) { 
     outputStream.write(buffer, 0, length); 
    } 
    inputStream.close(); 
    outputStream.close(); 
} 

    @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
     // Inflate the menu; this adds items to the action bar if it is present. 
     getMenuInflater().inflate(R.menu.famous_person, menu); 
     return true; 
    } 

    public void DisplayContact(Cursor c) 
    { 
     Toast.makeText(this, 
       "id: " + c.getString(0) + "\n" + 
       "Name: " + c.getString(1) + "\n" + 
       "Email: " + c.getString(2), 
       Toast.LENGTH_LONG).show(); 
    } 
} 

Это трассировки стека, я не уверен, что это совершенно правильно

enter image description here

+1

Дайте трассировку стека –

+1

Plz опубликовать код своей базы данных. –

+0

сообщение logcat output – user755

ответ

0

Попробуйте это: -

lv.setListAdapter (новый ArrayAdapter (MyListActivity .tis, android.R.layout.simple_list_item_1, result));

Смежные вопросы