Динамические данные база данных
у меня есть база данных в mysql, которой я управляю с помощью php admin, данные запрашиваются приложением на android через PHP и JSON, все до сих пор идеально, что я хочу, чтобы каждый раз, когда я делаю изменения в phpadmin базы данных, такие как обновление, вставка удаления записей, это отражается в режиме реального времени или мгновенно в приложении без необходимости закрывать и открывать приложение, чтобы это произошло.. предложение, комментарий я буду очень благодарен, приветствия и спасибо за ваше внимание.
здесь класс:
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, она не будет переработана в приложение
3 answers
Вы должны сделать следующее:
- использовать
retrofit
как библиотека для выполнения запросов REST - каждый раз, когда вы делаете
insert
,delete
,update
, Вы должны добавить или удалить его из своегоadapter
и использовать методnotifyDataSetChanged()
, чтобы в автоматическом обновленииlistview
- программа с использованием парадигмы POO, чтобы сделать ваш код обслуживаемым и функциональным.
Довольно простым решением было бы применить к вашим записям "версию". Это будет заключаться в добавлении к каждой таблице вашего BDD, которую вы хотите проверить, нового числового столбца, который увеличивал бы его значение с каждым insert / update таблицы, которую вы наблюдаете. Это будет контролироваться с помощью trigger, который действовал с помощью update или insert. В зависимости от ваших потребностей это может не понадобиться для каждой таблицы, если вы не создадите новую таблицу с одной записью, которая была этим номером "версия".
Затем с каждого устройства при проверке, которую я выполнял каждые 8 секунд, можно сравнить последнюю версию этой таблицы / BDD, сохраненную устройством (SQLite, shared preferences и т. д.), С последним значением поля "версия". Если он отличается, Вы должны обновить данные.
Это неортодоксальное, но простое, на мой взгляд, решение, которое не потребовало бы использования API или "внешних" сервисов. Я на самом деле применил его для проекта, и он работает отлично.