2016-09-30 5 views
0

У меня есть активность, чтобы проверить, существуют ли идентификатор устройства и имя устройства в локальной базе данных (sqlite), и когда устройство уже зарегистрировано, я перейду к другому действию под названием ConnectToCostCenter код деятельности является:Проверить идентификатор и имя устройства в базе данных sqlite

public class StartActivity extends Activity { 

Handler handler = new Handler(); 
DBHandler dbHandler; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.start_activity); 
    dbHandler = new DBHandler(this); 
    handler.postDelayed(new Runnable() { 
     @Override 
     public void run() { 
      String DeviceId = Settings.Secure.getString(getContentResolver(), Settings.Secure.ANDROID_ID); 
      String DeviceName = Build.MODEL; 
      RegisterDevice cc = new RegisterDevice(DeviceId, DeviceName); 
      if (!dbHandler.getAllDevice().isEmpty() && (dbHandler.getAllDevice().contains(cc))){ 
       final Intent mainIntent = new Intent(StartActivity.this, ConnectToCostCenter.class); 
       startActivity(mainIntent); 
      } else { 
       Intent intent = new Intent(StartActivity.this, CreateOrEditActivity.class); 
       startActivity(intent); 
      } 
      StartActivity.this.finish(); 
     } 
    }, 3000); 
} 

}

и ArrayList:

public ArrayList<RegisterDevice> getAllDevice() { 
    SQLiteDatabase db = this.getReadableDatabase(); 
    ArrayList<RegisterDevice> activityList = null; 
    try{ 
     activityList = new ArrayList<RegisterDevice>(); 
     String QUERY = "SELECT * FROM "+DEVICE_TABLE_NAME; 
     Cursor cursor = db.rawQuery(QUERY, null); 
     if(!cursor.isLast()) 
     { 
      while (cursor.moveToNext()) 
      { 
       RegisterDevice activity = new RegisterDevice(); 

       activity.setDeviceId(cursor.getString(0)); 
       //  activity.setCreated(cursor.getString(2)); 
       // activity.setModified(cursor.getString(3)); 
       activity.setDeviceName(cursor.getString(1)); 
       activityList.add(activity); 
      } 
     } 
     db.close(); 
    }catch (Exception e){ 
     Log.e("error",e+""); 
    } 
    return activityList; 
} 

Проблема в том, что устройство существует в базе данных, тогда вместо CreateToStationStateStationStateStateStateToolsOctiveOctive появляется функция CreateOrEditActivity, а не HelpToCostCenter .

+0

отлаживайте свой код и проверяйте в своем db, содержит ли он строку, которую вы хотите проверить или нет. – Anjali

ответ

0

Я думаю, вы получаете немного путаницы в соответствии с условием, сделайте еще один способ, как вы будете перебирать список массивов и делать условие внутри цикла, можете ли вы получить истинное или ложное и сделать перенаправление деятельности там, где хотите.