2012-04-09 77 views
1

我創建了一個表,但我想創建兩個,當我點擊「顯示」按鈕時,我希望能夠從兩個表中選擇內容並顯示它們......這是我的代碼...我有問題創建兩個表,並顯示他們:在sqlite/android中創建兩個表並顯示其內容

public class Entername extends Activity { 

     private Button showButton; 
     private Button insertButton; 
     private TextView nameEditText; 
     private TextView addTextView; 
     private Button doneButton; 
     public DatabaseHelper dbHelper = new DatabaseHelper(Entername.this,"pubgolfdatabase",2); 
     /** Called when the activity is first created. */ 
     @Override 
     public void onCreate(Bundle savedInstanceState) 
     { 
      super.onCreate(savedInstanceState); 
      setContentView(R.layout.entername); 
      addTextView = (TextView)findViewById(R.id.textView1); 
      doneButton= (Button)findViewById(R.id.doneButton); 
      insertButton = (Button)findViewById(R.id.addButton); 
      nameEditText = (EditText)findViewById(R.id.name); 
      showButton =(Button)findViewById(R.id.button1); 
      showButton.setOnClickListener(new showButtonListener()); 
      insertButton.setOnClickListener(new InsertButtonListener()); 
      doneButton.setOnClickListener(new DoneButtonListener()); 

      /** create the database if it dosen't exist **/ 
      SQLiteDatabase db = dbHelper.getWritableDatabase(); 
      try 
      { 
       db.execSQL("create table user_name(ID integer, name varchar(90));");          
      } 
      catch(Exception e) 
      { 
       e.printStackTrace(); 
      }   
     } 

     class InsertButtonListener implements OnClickListener, android.view.View.OnClickListener 
     { 
      public void onClick(View v) 
      {     
       if("".equals(nameEditText.getText().toString())) 
       { 
        Toast toast = Toast.makeText(Entername.this, "Sorry, you must input both the name and the address!", Toast.LENGTH_LONG); 
        toast.show(); 
       } 
       else 
       { 
        long flag = 0; 
        int id = 1; 
        SQLiteDatabase db = dbHelper.getWritableDatabase(); 
        Cursor cursor = db.query("user_name", new String[]{"count(*) ID"}, null, null, null, null, null); 
        while(cursor.moveToNext()) 
        { 
         int idFromDatabase = cursor.getInt(cursor.getColumnIndex("ID")); 
         if(idFromDatabase != 0) 
         { 
          id = 1 + idFromDatabase; 
         } 
        } 
        ContentValues values = new ContentValues(); 
        values.put("ID", id); 
        values.put("name", nameEditText.getText().toString().trim()); 

        flag = db.insert("user_name", null, values); 
        if(flag != -1) 
        { 
         Toast toast = Toast.makeText(Entername.this, "You have successful inserted this record into database! ", Toast.LENGTH_LONG); 
         toast.show(); 
         db.close(); 

         //clear fields    //clearing edittexts 
          nameEditText.setText(""); 

         return; 
        } 
        else 
        { 
         Toast toast = Toast.makeText(Entername.this, "An error occured when insert this record into database!", Toast.LENGTH_LONG); 
         toast.show(); 
         db.close(); 

         //clear fields 
         //clearing edittexts 
          nameEditText.setText(""); 
         return; 
        } 
       } 
      } 

      public void onClick(DialogInterface dialog, int which) 
      { 
       // TODO Auto-generated method stub 
      } 
     } 

     class DoneButtonListener implements OnClickListener, android.view.View.OnClickListener 
     { 
      public void onClick(View v) 
      { 
       Intent myIntent = new Intent(v.getContext(), Pickholespubs.class); 
       startActivityForResult(myIntent, 0); 
      } 

      public void onClick(DialogInterface dialog, int which) 
      { 
       // TODO Auto-generated method stub 
      } 
     } 

     class showButtonListener implements OnClickListener, android.view.View.OnClickListener 
     { 
      public void onClick(View v) 
      { 
       String display = ""; 
       SQLiteDatabase db = dbHelper.getWritableDatabase(); 
       /** the result will be loaded in cursor **/ 
       Cursor cursor = db.query("user_name", new String[]{"ID","name"}, null, null, null, null, null); 
       /** check if the table is empty **/ 
       if (!cursor.moveToNext()) 
       { 
        addTextView.setText("No data to display, please make sure you have already inserted data!"); 
        db.close(); 
        return; 
       } 
       cursor.moveToPrevious(); 
       /** if the table is not empty, read the result into a string named display **/ 
       while(cursor.moveToNext()) 
       { 
        int ID = cursor.getInt(cursor.getColumnIndex("ID")); 
        String name = cursor.getString(cursor.getColumnIndex("name")); 

        display = display + "\n"+"Player"+ID+", Name: "+name; 
       } 
       /** display the result on the phone **/ 
       addTextView.setText(display); 
       db.close(); 
      } 

      public void onClick(DialogInterface dialog, int which) 
      { 
       // TODO Auto-generated method stub 
      } 
     } 
} 
+0

你能解釋爲什麼你不想在'dbHelper.onCreate'中創建第二張表嗎?沒有什麼能阻止你在那裏創建多個表格。 – CjS 2012-04-10 06:41:13

+0

哦,我不知道我可以做到這一點,因爲我在一張桌子上創建了一個頁面..我可以在那裏創建嗎? – user1179083 2012-04-11 15:24:19

+0

你可以/ /所有/ /你的數據庫管理DBHelper回調(onCreate,onUpgrade等) – CjS 2012-04-11 16:51:42

回答

5

嘗試這樣,

@Override 
    public void onCreate(SQLiteDatabase db) { 
     String CREATE_CONTACTS_TABLE = "CREATE TABLE " + TABLE_DETAILS + "(" 
       + KEY_ID + " INTEGER PRIMARY KEY," + KEY_NAME + " TEXT," 
       + KEY_NUMBER + " TEXT," + KEY_MAIL + " TEXT" + ")"; 
     db.execSQL(CREATE_CONTACTS_TABLE); 
     String CREATE_ONLINE_TABLE = "CREATE TABLE " + TABLE_ONLINE_DETAILS + "(" 
       + KEY_ID + " INTEGER PRIMARY KEY," + KEY_NAME + " TEXT," 
       + KEY_MAIL + " TEXT," + KEY_PHONE + " TEXT"+ ")"; 
     db.execSQL(CREATE_ONLINE_TABLE); 

    } 
    @Override 
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 
     db.execSQL("DROP TABLE IF EXISTS " + TABLE_DETAILS); 
     db.execSQL("DROP TABLE IF EXISTS " + TABLE_ONLINE_DETAILS); 
     onCreate(db); 
     } 

可以調用該方法在Java類像

db.add(String, String, String); 
相關問題