Проверьте идентификатор устройства и имя в базе данных sqlite

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

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;
}

Проблема заключается в том, что если устройство существует в базе данных, то вместо ConnectToCostCenter появляется активность CreateOrEditActivity.

1 ответ

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

Другие вопросы по тегам