2011-03-09 7 views
0

DB 어댑터 클래스를 만들었습니다.이 테이블은 Users_Details 및 Creditcard_Details라는 두 개의 테이블을 생성해야합니다. 그러나 내 데이터베이스를 내 보낸 후 SQLite Browser로 만든 데이터베이스를 검사했을 때 이전 테이블 만 만들었습니다. 나는 이것이 무엇을 일으키는 지 이해할 수 없습니다. 누군가이 문제를 제안하거나 도움을 줄 수 있습니까?안드로이드에서 SQLite에 두 번째 테이블을 만들 수 없습니다.

다음은 DB 어댑터에 대한 코드입니다 :

package com.androidbook.LoginForm; 

    import android.content.ContentValues; 
    import android.content.Context; 
    import android.database.Cursor; 
    import android.database.SQLException; 
    import android.database.sqlite.SQLiteDatabase; 
    import android.database.sqlite.SQLiteOpenHelper; 
import android.util.Log; 


public class DBAdapter { 
     /*------------------------User Details ---------------------------------*/ 
     public static Cursor d; 
     public static final String KEY_ROWID = "_id"; 
     public static final String KEY_Name = "name"; 
     public static final String KEY_Username = "username"; 
     public static final String KEY_Password = "password"; 

     private static final String TAG = "DBAdapter"; 

     private static final String DATABASE_NAME = "Wallet"; 
     private static final String DATABASE_TABLE = "User_Details"; 

     /*------------------------Credit Cards Table----------------------*/ 

     private static final String KEY_CCID = "_ccid"; 
     private static final String KEY_CCUNAME= "cuname"; 
     private static final String KEY_CCNO = "ccno"; 
     private static final String KEY_CVV = "cvvno"; 
     private static final String EXP_DATE = "expdate"; 
     private static final String CREDITCARDS_TABLE = "Creditcard_Details"; 

     private static final int DATABASE_VERSION = 1; 

     private static final String DATABASE_CREATE = 
      "create table"+ DATABASE_TABLE + " (" + KEY_ROWID + " integer primary key autoincrement, " 
      + KEY_Name + " text not null, " + KEY_Username + " text not null, " 
      + KEY_Password + " text not null);"; 

     private static final String CCTABLE_CREATE = "create table " + 
     CREDITCARDS_TABLE + " (" + KEY_CCID + 
     " integer primary key autoincrement, " + 
     KEY_CCUNAME + "text not null, " + KEY_CCNO + " text not null, " + KEY_CVV + " text not null, " + EXP_DATE + " text not null);"; 
     /*---------------------Create Credit Card Table -------------------------------*/ 
     /* private static final String CCTABLE_CREATE = 
      "create table"+ CREDITCARDS_TABLE + " (" + KEY_CCID + " integer primary key , " 
      + KEY_CCUNAME + " text not null, " + KEY_CCNO + " ccno text not null, " 
      + KEY_CVV + " text not null, " + EXP_DATE + " text not null);";//+ "FOREIGN KEY(_ccid) REFERENCES User_Details(_id))"; 
     */ 
     private final Context context; 
     public DatabaseHelper DBHelper; 
     private SQLiteDatabase db; 

     public DBAdapter(Context ctx) 
     { 
      this.context = ctx; 
      DBHelper = new DatabaseHelper(context); 
     } 

     private static class DatabaseHelper extends SQLiteOpenHelper 
     { 
      DatabaseHelper(Context context) 
      { 
       super(context, DATABASE_NAME, null, DATABASE_VERSION); 
      } 

      @Override 
      public void onCreate(SQLiteDatabase db) 
      { 
       db.execSQL(DATABASE_CREATE); 
       db.execSQL(CCTABLE_CREATE); 

      } 

      @Override 
      public void onUpgrade(SQLiteDatabase db, int oldVersion, 
            int newVersion) 
      { 
       Log.w(TAG, "Upgrading database from version " + oldVersion 
         + " to " 
         + newVersion + ", which will destroy all old data"); 
       db.execSQL("DROP TABLE IF EXISTS titles"); 
       onCreate(db); 
      } 
     } 
     public int Login(String username,String password) 
     { 
     try 
     { 
      Cursor c = null; 
      c = db.rawQuery("select * from User_Details where username =" + "\""+ username + "\""+" and password="+ "\""+ password + "\"", null); 
      c.moveToFirst(); 
      //Toast.makeText(DBAdapter.this, "correct"+" "+c,Toast.LENGTH_LONG).show(); 
      d= c;//CCview(tempid); 
      return c.getCount(); 
     } 
     catch(Exception e) 
     { 
      e.printStackTrace(); 
      } 

     return 0; 
     } 


     //-----------------------Display Credit Card ----------------------------- 

     /* public int Getid(String tempid) 
     { Cursor c; 
      c = db.rawQuery("select id from User_Details where username =" 
        + "\""+ username + "\"", null); 

      return Integer.parseInt(c.getString(0)); 

     }*/ 



     public Cursor CCview(long menuid)throws SQLException 

     { 

      Cursor mCursor = 
        db.query(true, CREDITCARDS_TABLE, new String[] { 
          KEY_CCID, 
          KEY_CCUNAME, 
          KEY_CCNO, 
          KEY_CVV, 
          EXP_DATE, 
          }, 
          KEY_CCID + "=" + menuid, 
          null, 
          null, 
          null, 
          null, 
          null); 
      if (mCursor != null) { 
       mCursor.moveToFirst(); 
      } 
      return mCursor; 
     } 



     //--------------------Entries into Credit Card Table------------------------------------ 
     //---insert a title into the database--- 

     public long insertCreditcard(String j, String k, String l, String date) 
     { 


      ContentValues creditValues = new ContentValues(); 
      // creditValues.put(KEY_CCID, i); 
      creditValues.put(KEY_CCUNAME, j); 
      creditValues.put(KEY_CCNO, k); 
      creditValues.put(KEY_CVV, l); 
      creditValues.put(EXP_DATE, date); 
      return db.insert(CREDITCARDS_TABLE, null, creditValues); 
     } 


     //---opens the database--- 
     public DBAdapter open() throws SQLException 
     { 
      db = DBHelper.getWritableDatabase(); 

      return this; 
     } 

     //---closes the database---  
     public void close() 
     { 
      DBHelper.close(); 
     } 

     //---insert a title into the database--- 
     public long insertTitle(String name, String username, String password) 
     { 
      ContentValues initialValues = new ContentValues(); 
      initialValues.put(KEY_Name, name); 
      initialValues.put(KEY_Username, username); 
      initialValues.put(KEY_Password, password); 
      return db.insert(DATABASE_TABLE, null, initialValues); 
     } 

     //---deletes a particular title--- 
     public boolean deleteTitle(long rowId) 
     { 
      return db.delete(DATABASE_TABLE, KEY_ROWID + "=" + rowId, null) > 0; 
     } 

     //---retrieves all the titles--- 
     public Cursor getAllTitles() 
     { 
      return db.query(DATABASE_TABLE, new String[] { 
        KEY_ROWID, 
        KEY_Name, 
        KEY_Username, 
        KEY_Password}, 
        null, 
        null, 
        null, 
        null, 
        null); 
     } 

     //---retrieves a particular title--- 
     public Cursor getTitle(long rowId) throws SQLException 
     { 
      Cursor mCursor = 
        db.query(true, DATABASE_TABLE, new String[] { 
          KEY_ROWID, 
          KEY_Name, 
          KEY_Username, 
          KEY_Password 
          }, 
          KEY_ROWID + "=" + rowId, 
          null, 
          null, 
          null, 
          null, 
          null); 
      if (mCursor != null) { 
       mCursor.moveToFirst(); 
      } 
      return mCursor; 
     } 

     //---updates a title--- 
     public boolean updateTitle(long rowId, String name, 
     String username, String password) 
     { 
      ContentValues args = new ContentValues(); 
      args.put(KEY_Name, name); 
      args.put(KEY_Username, username); 
      args.put(KEY_Password, password); 
      return db.update(DATABASE_TABLE, args, 
          KEY_ROWID + "=" + rowId, null) > 0; 
     } 
    } 
+0

"create table"-> "create table"이 DATABASE_CREATE에 있습니까? –

답변

0

는 DATABASE_VERSION 번호를 변경하려고합니다. 왜냐하면 당신이 개발 중에 아마 하나의 테이블 (그리고 db_ver가 1)을 가지고 있었고 코드에 2 번째 테이블을 추가했기 때문입니다. 그러나 그것은 나타나지 않았습니다.

또는 제거 + 재설치로이를 수행 할 수 있습니다.

+0

감사합니다, 그것을 시도했지만 나던 작동하지 않는 것 같습니다 – arun

+0

또한 거기에 있는지 확인하십시오; 예를 들어, "create table t1 (c1, c2);" (나는 쉽게 볼 수 없다 ...) – SteelBytes

관련 문제