Как получить конкретные данные строки из базы данных разбора для Android
У меня есть учетная запись Parse Dashboard, в которой у меня есть класс PointsCollected. Для этого класса у меня есть поля в качестве устройства,pointsObtained.
Мой вопрос заключается в том, что мне нужно получить очки на основе устройства. Я получаю идентификатор устройства от менеджера по телефону. Но как сделать запрос для получения точек на основе идентификатора устройства, и, если строк не найдено, он показывает добавление строки с нулевыми точками в базу данных.
1 ответ
Решение
Вы можете сделать это, если поместите пользователя в одну таблицу.
ParseQuery<ParseObject> query = ParseQuery.getQuery("PointsCollected");
query.whereEqualTo("currentUser", currentUset.getObjectId());
// this will find the user.
// then find the first instance
query.findFirstInBackground(new FindCallback<ParseObject>() {
public void done(List<ParseObject> object, ParseException e) {
if (e == null) {
textView.setText(object.getString("device"));
} else {
Log.d(TAG, "Error: " + e.getMessage());
}
}
});
Это новая идея.... Это должно работать.
// At the end we want to get the points.
final int points;
//First, lets get the ID of the device and store that into a veriable.
TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
final String deviceId = telephonyManager.getDeviceId().toString();
//Then lets query the PointsCollected database.
ParseQuery<ParseObject> query = ParseQuery.getQuery("PointsCollected");
// Then we want to see where the DeviceID (from the variable) matches the device from the database.
// "device" is the row in the database.
// deviceID is the varible that is storing that users device ID.
query.whereEqualTo("device", deviceId);
//Then we get the first instance...
query.getFirstInBackground(new GetCallback<ParseObject>() {
public void done(ParseObject object, ParseException e) {
// you want to do a check on the ParseException here as well.
if (object == null) {
Log.d("nothing found", "let's go ahead and create a new object.");
//ADD THE OBJECT AS A NEW OBJECT!!!!
} else {
points = object.getInt("pointsObtained");
Log.d("points found", points + "");
}
}
});