2012-05-11 37 views
4

我hv开发了一个具有C2DM功能的项目。只要服务器上有可用的数据;服务器将数据推送到所有这个应用程序的设备(在我的情况下它是一个小的味精)。Sqlite数据库应该只创建一次

现在的问题是做每一个数据库和表会被创建时,其中一个消息传出, 这里是我的代码,

public class MessageHelper extends Activity 
    { 
     public String str; 
     public int sts; 
     public Date timeStamp; 

     protected void onCreate(Bundle savedInstanceState) 
     { 
      super.onCreate(savedInstanceState); 
      setContentView(R.layout.main); 

      Bundle extras = getIntent().getExtras(); 
      if (extras != null) { 
       this.str = extras.getString("msgg"); 
       Log.d("C2DM", this.str); 
      } 

      // Create a ref of SQLite 
      SQLiteDatabase db; 

      //use tat ref to open or create a table 
      db = openOrCreateDatabase("/data/data/de.vogella.android.c2dm.simpleclient/app_database/file__0/0000000000000001.db", SQLiteDatabase.CREATE_IF_NECESSARY, null); 

      try 
      { 
       //initialsiging a query with all the table fields 
       final String CREATE_TABLE_CONTAIN = "CREATE TABLE IF NOT EXISTS tbl_Message4(" 
         + "id INTEGER PRIMARY KEY AUTOINCREMENT," 
         + "msg TEXT not null," 
         + "msg_time INTEGER not null," 
         + "msg_status INTEGER not null);"; 

       //execute the above query 
       db.execSQL(CREATE_TABLE_CONTAIN); 

       timeStamp = new Date(); 

       String sql = 
         "INSERT or replace INTO tbl_Message4 (msg,msg_time,msg_status) VALUES('"+this.str+"' ,'"+this.timeStamp+"' , 0)" ;  
       db.execSQL(sql); 
     } 
    } 

我也有叫MessageReceiver类延伸的BroadcastReceiver; eveytime消息来该类被执行这inturn加载MessageHelper.class 这里是的messageReceiver代码,

public class C2DMMessageReceiver extends BroadcastReceiver { 

    @Override 
    public void onReceive(Context context, Intent intent) { 
     String action = intent.getAction(); 
     Log.w("C2DM", "Message Receiver called"); 
     if ("com.google.android.c2dm.intent.RECEIVE".equals(action)) { 
      Log.w("C2DM", "Received message"); 
      final String payload = intent.getStringExtra("payload"); 
      Log.d("C2DM", "dmControl: payload = " + payload); 
      // TODO Send this to my application server to get the real data 
      // Lets make something visible to show that we received the message 
      createNotification(context, payload); 

     } 
    } 

    public void createNotification(Context context, String payload) { 
     NotificationManager notificationManager = (NotificationManager) context 
       .getSystemService(Context.NOTIFICATION_SERVICE); 
     Notification notification = new Notification(R.drawable.ic_launcher, 
       "Message received", System.currentTimeMillis()); 
     // Hide the notification after its selected 
     notification.flags |= Notification.FLAG_AUTO_CANCEL; 

     //Intent intent = new Intent(context, MessageReceivedActivity.class); 
     //intent.putExtra("payload", payload); 

     Intent intent = new Intent(context, MessageHelper.class); 
     intent.putExtra("msgg", payload); 
     intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
     context.startActivity(intent); 
     //PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0); 
     //notification.setLatestEventInfo(context, "Message", "New message received", pendingIntent); 
     //notificationManager.notify(0, notification); 

    } 

} 

什么,我期待的是,当应用程序是应建立一个数据库第一次安装。

由于提前,

TheIlleterate

+1

请参阅http://www.vogella.com/articles/AndroidSQLite/article.html#databasetutorial中的'SQLiteOpenHelper' - 它只会在需要时创建数据库。 – zapl

回答

2

数据库将被创建一次,因为它的名字没有被改变。是的,它只会在您的应用第一次启动活动MessageHelper时才创建。

0

“CREATE TABLE IF NOT EXISTS” 将创建表只有当它已不存在。 所以它只会创建一次。 你是否在其他地方删除此表?