Относительно базы данных Android - PullRequest
0 голосов
/ 23 февраля 2011

Hot To Создать таблицу в базе данных только один раз и вставить данные в эту таблицу несколько раз в Android, используя SQLite DB ... ??

Ответы [ 3 ]

2 голосов
/ 23 февраля 2011

Лот примеров доступен в сети.Смотрите эти ссылки для справки:

0 голосов
/ 09 марта 2011

Это мой класс активности

открытый класс d extends Activity {

/ ** Вызывается при первом создании действия.* /

@ Переопределить public void onCreate (BundlevedInstanceState) {

super.onCreate (saveInstanceState);

setContentView (R.layout.main);

    String name=getIntent().getStringExtra("name");
    String email=getIntent().getStringExtra("email");
    String phone=getIntent().getStringExtra("phone");

    Log.e("d3","came to other activity");
    SmartDBHelper d=new SmartDBHelper(getApplicationContext());
   d.open();
   d.insertTitle(name, phone, email);
  Cursor c=d.getAllTitles();
  // c.getColumnName(0); 

  for( int i=0;i<c.getCount();i++){
  if(c.moveToNext()){
      Log.e("c", ""+ c.getString(0) );    
      Log.e("d", ""+ c.getString(1) );
      Log.e("d4", ""+ c.getString(2) );   


  }
Log.e("r",""+c.getCount());
finish();
  }

}

}

вот мой класс sqllite

открытый класс SmartDBHelper extends SQLiteOpenHelper {

private SQLiteDatabase dBH;
private static final String DATABASE_NAME = "yo.db";  
private static final int DATABASE_VERSION = 2;  
private static final String NOTIFY_TABLE_NAME = "user_notify_data"; 
private static final String HR_TABLE_NAME = "user_hr_data";  
private static final String NOTIFY_TABLE_CREATE =  
    "CREATE TABLE " + NOTIFY_TABLE_NAME + " (counter INTEGER PRIMARY KEY, " + 
    "userresponse TEXT, " + 
    "notifytime TEXT);";  


private static final String HR_TABLE_CREATE = 
    "CREATE TABLE " + HR_TABLE_NAME +  
    " (counter INTEGER PRIMARY KEY, " +   
    "hr TEXT, " + 
    "act TEXT, " + 
    "timestamp TEXT);";

public SmartDBHelper(Context context) { 
    super(context, DATABASE_NAME, null, DATABASE_VERSION); 
    // TODO Auto-generated constructor stub   
    }  

@Override 
public void onCreate(SQLiteDatabase db) { 
        // TODO Auto-generated method stub     
        Log.e("smartdbhelper", "before creation");    
        db.execSQL(NOTIFY_TABLE_CREATE);      
        Log.e("smartdbhelper", "middle creation"); 
        db.execSQL(HR_TABLE_CREATE);       
        Log.e("smartdbhelper", "after creation");  
        }   

    @Override   
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 
        // TODO Auto-generated method stub     
        } 

    public SmartDBHelper open() throws SQLException 
    {
          dBH = getWritableDatabase(); 
         return this;
    }

    public long insertTitle(String isbn, String title, String publisher) 
    {
        ContentValues initialValues = new ContentValues();
        initialValues.put("hr", isbn);
        initialValues.put("act", title);
        initialValues.put("timestamp", publisher);
        Log.e("insertes","i");

         dBH.insert(HR_TABLE_NAME, null, initialValues);

return 11111111;}

    public Cursor getAllTitles() 
    {
        return dBH.query(HR_TABLE_NAME, new String[] {
                 "hr","act","timestamp"},null, 
                null, 
                null, 
                null, 
                null);
    }








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

}

}

/ * приведенный выше код работает и был протестирован * /

0 голосов
/ 23 февраля 2011

Вы должны быть подклассом SQLiteOpenHelper и использовать его удобные методы, которые устранят большую сложность использования SQLite.См. Хранение данных

Взгляните на образец NotePadProvider .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...