Динамические данные база данных

У меня есть база данных в mysql, которым я управляю с php admin, данные консультировались приложением в android через PHP и JSON, все до сих пор совершенное, что я хочу, состоит в том, чтобы каждый раз, когда я реализовал изменение в phpadmin базы данных, как обновление, вводить удалять реестры, это оказалось отраженным в реальном времени или моментальной формы в app без необходимости быть должным закрывать и открывать app для того, чтобы это произошел. который quier подсказка, комментарий я ему буду благодарен за это много, привет и спасибо за Ваше внимание.

Здесь класс:

  public class VerA extends ActionBarActivity {

  String myJSON;

  private static final String TAG_RESULTS="result";
private static final String TAG_ID = "id";
private static final String TAG_NAME = "nombre";
private static final String TAG_ADD ="telefono";
private Handler mHandler;
private int mInterval = 8000; // 5 seconds by default, can be changed later


JSONArray peoples = null;

ArrayList<HashMap<String, String>> personList;

ListView list;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    list = (ListView) findViewById(R.id.listView);
    personList = new ArrayList<HashMap<String,String>>();
    mHandler = new Handler();
    startRepeatingTask();
    getData();



}

// METODO QUE MUESTRA LA LISTA O LA MATRIZ
protected void showList(){
    try {
        JSONObject jsonObj = new JSONObject(myJSON);
        peoples = jsonObj.getJSONArray(TAG_RESULTS);

        for(int i=0;i<peoples.length();i++){
            JSONObject c = peoples.getJSONObject(i);
            String id = c.getString(TAG_ID);
            String name = c.getString(TAG_NAME);
            String address = c.getString(TAG_ADD);

            HashMap<String,String> persons = new HashMap<String,String>();

            persons.put(TAG_ID,id);
            persons.put(TAG_NAME,name);
            persons.put(TAG_ADD,address);

            personList.add(persons);
        }

        ListAdapter adapter = new SimpleAdapter(
                VerA.this, personList, R.layout.list_item,
                new String[]{TAG_ID,TAG_NAME,TAG_ADD},
                new int[]{R.id.id, R.id.name, R.id.address}
        );

        list.setAdapter(adapter);

    } catch (JSONException e) {
        e.printStackTrace();
    }

}


///METODO QUE EXTRAE LOS DATOS DE EL JASON PHP
public void getData(){
    class GetDataJSON extends AsyncTask<String, Void, String>{

        @Override
        protected String doInBackground(String... params) {
            DefaultHttpClient httpclient = new DefaultHttpClient(new BasicHttpParams());
            HttpPost httppost = new HttpPost("http://192.168.1.108/selectAllJSON.php");

            // Depends on your web service
            httppost.setHeader("Content-type", "application/json");

            InputStream inputStream = null;
            String result = null;
            try {

                HttpResponse response = httpclient.execute(httppost);
                HttpEntity entity = response.getEntity();

                inputStream = entity.getContent();
                // json is UTF-8 by default
                BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, "UTF-8"), 8);
                StringBuilder sb = new StringBuilder();

                String line = null;
                while ((line = reader.readLine()) != null)
                {
                    sb.append(line + "\n");
                }
                result = sb.toString();
            } catch (Exception e) {
                // Oops
            }
            finally {
                try{if(inputStream != null)inputStream.close();}catch(Exception squish){}
            }
            return result;
        }

        @Override
        protected void onPostExecute(String result){
            myJSON=result;
            showList();
        }
    }
    GetDataJSON g = new GetDataJSON();
    g.execute();
}


  /// METODO PARA HACER QUE SE EJECUTE LA CONSULTA A LA BD CADA 8 SEGUNDOS, EL QUE NO FUNCIONA 
Runnable mStatusChecker = new Runnable() {
    @Override
    public void run() {
        getData();
        mHandler.postDelayed(mStatusChecker, mInterval);
    }
};
void startRepeatingTask() {
    mStatusChecker.run();
}
}

Последнее изменение в код:

 public class VerA extends ActionBarActivity {

String myJSON;

private static final String TAG_RESULTS="result";
private static final String TAG_ID = "id";
private static final String TAG_NAME = "nombre";
private static final String TAG_ADD ="telefono";
Handler handler = new Handler();


JSONArray peoples = null;

ArrayList<HashMap<String, String>> personList;

ListView list;




@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    list = (ListView) findViewById(R.id.listView);
    personList = new ArrayList<HashMap<String,String>>();
    handler.postDelayed(runnable, 1000);
    getData();



}



 // METODO QUE MUESTRA LA LISTA O LA MATRIZ
protected void showList(){
    try {
        JSONObject jsonObj = new JSONObject(myJSON);
        peoples = jsonObj.getJSONArray(TAG_RESULTS);

        for(int i=0;i<peoples.length();i++){
            JSONObject c = peoples.getJSONObject(i);
            String id = c.getString(TAG_ID);
            String name = c.getString(TAG_NAME);
            String address = c.getString(TAG_ADD);

            HashMap<String,String> persons = new HashMap<String,String>();

            persons.put(TAG_ID,id);
            persons.put(TAG_NAME,name);
            persons.put(TAG_ADD,address);

            personList.add(persons);
        }

        ListAdapter adapter = new SimpleAdapter(
                VerA.this, personList, R.layout.list_item,
                new String[]{TAG_ID,TAG_NAME,TAG_ADD},
                new int[]{R.id.id, R.id.name, R.id.address}
        );

        list.setAdapter(adapter);

    } catch (JSONException e) {
        e.printStackTrace();
    }

}


  ///METODO QUE EXTRAE LOS DATOS DE EL JASON PHP
public void getData(){
    class GetDataJSON extends AsyncTask<String, Void, String>{

        @Override
        protected String doInBackground(String... params) {
            DefaultHttpClient httpclient = new DefaultHttpClient(new BasicHttpParams());
            HttpPost httppost = new HttpPost("http://tuescuelanoticias.x10.mx/selectAllJSON.php");

            // Depends on your web service
            httppost.setHeader("Content-type", "application/json");

            InputStream inputStream = null;
            String result = null;
            try {

                HttpResponse response = httpclient.execute(httppost);
                HttpEntity entity = response.getEntity();

                inputStream = entity.getContent();
                // json is UTF-8 by default
                BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, "UTF-8"), 8);
                StringBuilder sb = new StringBuilder();

                String line = null;
                while ((line = reader.readLine()) != null)
                {
                    sb.append(line + "\n");
                }
                result = sb.toString();
            } catch (Exception e) {
                // Oops
            }
            finally {
                try{if(inputStream != null)inputStream.close();}catch(Exception squish){}
            }
            return result;
        }

        @Override
        protected void onPostExecute(String result){
            myJSON=result;
            showList();
        }
    }
    GetDataJSON g = new GetDataJSON();
    g.execute();
}


 ///LOS METODOS SIGUIENTES MUESTRAN LA OPCION DE MENU Y CONFIGRUACIO
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.menu_main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();

    //noinspection SimplifiableIfStatement
    if (id == R.id.action_settings) {
        return true;
    }

    return super.onOptionsItemSelected(item);

}
 ///DISQUE PARA QUE SE REFRESQUE CADA 8 SEGUNDOS
 private Runnable runnable = new Runnable() {
 public void run() {
    showList();
        // Do some updates
        handler.postDelayed(this, 8000);

  }
  };


  }

выполнив это в конечной остановке или в моем мобильном телефоне, каждые 8 секунд повторяются данные, но если я изменяю с php admin базу данных, не refelja в app

3
задан 06.01.2016, 18:30
3 ответа

Принимая во внимание, что говорится о приложении Android, стратегия, сообщать aplicativo Android, когда случилось изменение в дате твоего backend, чтобы потом стрелять в операцию обновления данных в BD твоей команды, - самое рекомендуемое.

Я оставляю тебе маленькое графическое объяснение. Я надеюсь, что он помогает тебе. introducir la descripción de la imagen aquí

4
ответ дан 24.11.2019, 15:01

Ты должен делать следующее:

  1. , Использовать такие retrofit как библиотека, чтобы делать просьбы REST
  2. Каждый раз, когда ты сделал один insert, один delete, один update, ты должен добавлять или удалять тебя adapter, и использовать метод notifyDataSetChanged(), для того, чтобы в автоматическом обновили listview
  3. , Запрограммируй используя парадигму POO для того, чтобы ты cГіdigo он был mantenible и функционально.
1
ответ дан 24.11.2019, 15:01
  • 1
    спасибо pro Ваши ответы и комментарии C и # 233; sar и ClarkXP @honestamente я новый в Poo и в andorid, едва защищаюсь в php, если app, к которому я стремлюсь только, - вид браузера объявлений, он и # 237; do на извещениях push и GCM, и то, что я понимаю, состоит в том, что функционирование состояло бы сходным, так как услуги google постоянно в том, чтобы быть и # 237; an проверяя базу данных, следовательно pens и # 233; в делании более независимым от услуг google, и что сам app каждые X секунд проверил базу данных – JESUS ESPINOSA 05.01.2016, 23:43
  • 2
    в php был бы чем-то очень f и # 225; cil, так как только он сделал бы прямую консультацию, и с javscript, что страница стала отвечающей совремнным требованиям каждые X секунд тогда, escript php работает снова показывая снова данные, и если я изменяю в php admins данные, они отражаются, вот более или менее то, что хотело, чтобы было возможно делать какой-то формы.... – JESUS ESPINOSA 05.01.2016, 23:48
  • 3
    следующее соединение - случая сходного с моим, но мне не удается помочь c и # 243; я говорю: stackoverflow.com/questions/26045217/android-json-auto-refresh – JESUS ESPINOSA 06.01.2016, 00:33

Одна soluciГіn достаточно простая serГ, - чтобы применять к твоим реестрам одну "versiГіn". ConsistirГ - в в aГ±adir в каждую таблицу твоего BDD, что ты хотел подтвердить новую колонну numГ©rica, что увеличивал Вашу стоимость с каждым insert/update таблицы, который был нужно наблюдать. Это controlarГ - в посредством trigger, который действовал с update или insert. SegГєn твоя необходимость возможно, что не нужно делать в каждой таблице, если, не создавать новую таблицу с Гєnico, я регистрирую, что он был этим nГєmero "versiГіn".

Потом, с каждого устройства, в ней comprobaciГіn, что делал каждые 8 секунд podrГ, - когда Гєltima сравнивала versiГіn этого tabla/BDD, у которого было сохраняемая устройство (SQLite, shared preferences, и т.д.), с Гєltimo, стоимость поля "versiГіn". Если Г©sta он отличался, deberГ, - чтобы обновлять данные.

- один soluciГіn мало ортодоксальная но простая, во мне opiniГіn, и что не requerirГ, - чтобы использовать APгs или "внешние" услуги. В самом деле, она apliquГ¬ для проекта и функционируй верно.

1
ответ дан 24.11.2019, 15:01