Json array to object - android
How can i convert this json array to a json object. And i need to store this json to a remote server. How can i do it. I cannot find a perfect tutorial for this purpose.
private JSONArray getResults() {
String myPath = "/data/data/com.example.sebastian.patientdetails/databases/" + "MyDBName.db";
String myTable = "patients";
SQLiteDatabase myDataBase = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);
String searchQuery = "SELECT * FROM " + myTable;
Cursor cursor = myDataBase.rawQuery(searchQuery, null);
JSONArray resultSet = new JSONArray();
cursor.moveToFirst();
while (!cursor.isAfterLast()) {
int totalColumn = cursor.getColumnCount();
JSONObject rowObject = new JSONObject();
for (int i = 0; i < totalColumn; i++) {
if (cursor.getColumnName(i) != null) {
try {
if (cursor.getString(i) != null) {
Log.d("TAG_NAME", cursor.getString(i));
rowObject.put(cursor.getColumnName(i), cursor.getString(i));
} else {
rowObject.put(cursor.getColumnName(i), "");
}
} catch (Exception e) {
Log.d("TAG_NAME", e.getMessage());
}
}
}
resultSet.put(rowObject);
cursor.moveToNext();
}
cursor.close();
Log.d("TAG_NAME", resultSet.toString());
return resultSet;
}
while (!cursor.isAfterLast()) {
int totalColumn = cursor.getColumnCount();
JSONObject rowObject = new JSONObject();
//new jsonarray
JSONArray jsonArray=new JSONArray();
for (int i = 0; i < totalColumn; i++) {
if (cursor.getColumnName(i) != null) {
//new jsonarray of items jsonObject
JSONObject object = new JSONObject();
try {
if (cursor.getString(i) != null) {
Log.d("TAG_NAME", cursor.getString(i));
object.put(cursor.getColumnName(i),cursor.getString(i));
} else {
object .put(cursor.getColumnName(i), "");
}
//put jsonarray
jsonArray.put(object );
} catch (Exception e) {
Log.d("TAG_NAME", e.getMessage());
}
}
}
//put request jsonobject
rowObject.put(jsonArray);
resultSet.put(rowObject);
cursor.moveToNext();
}
you can use Google of Gson.jar,
There is a method to convert json array into jsonObject,
JSONArray array;
for(int n = 0; n < array.length(); n++)
{
JSONObject object = array.getJSONObject(n);
//do what ever you want
}
Related
Android SQLite query optimization (ORM GreenDao)
My job is to maintain an application that is essentially a database for another application. the application uses ORM GreenDao. Here is StorageUtil.getResults method which processes queries: public static JSONArray getResults(Database database, String query) { Cursor cursor = database.rawQuery(query, null); JSONArray resultSet = new JSONArray(); cursor.moveToFirst(); while (!cursor.isAfterLast()) { int totalColumn = cursor.getColumnCount(); JSONObject rowObject = new JSONObject(); for (int i = 0; i < totalColumn; i++) { if (cursor.getColumnName(i) != null) { try { if (cursor.getString(i) != null) { if (isJSONValid(cursor.getString(i))) { try { JSONObject object = new JSONObject(cursor.getString(i)); rowObject.put(cursor.getColumnName(i), object); }catch (JSONException e){ Logger.error(e); } } else { rowObject.put(cursor.getColumnName(i), cursor.getString(i)); } } else { rowObject.put(cursor.getColumnName(i), ""); } } catch (Exception e) { Logger.error(e); } } } resultSet.put(rowObject); cursor.moveToNext(); } cursor.close(); return resultSet; } Here is code of one of my entities: #Entity(nameInDb = "UI_SV_FIAS") #Storage(description = "FIAS", table = "UI_SV_FIAS") public class Fias { #Id public String LINK; #Property(nameInDb = "F_Street") public String F_Street; #Property(nameInDb = "C_Full_Address") #Index public String C_Full_Address; #Property(nameInDb = "C_House_Number") public String C_House_Number; #Property(nameInDb = "C_Building_Number") public String C_Building_Number; public Fias() { } #Generated(hash = 1534843169) public Fias(String LINK, String F_Street, String C_Full_Address, String C_House_Number, String C_Building_Number) { this.LINK = LINK; this.F_Street = F_Street; this.C_Full_Address = C_Full_Address; this.C_House_Number = C_House_Number; this.C_Building_Number = C_Building_Number; } Problem: the table has about 2,500,000 rows and when I get a query, for example, like this one: http://localhost:8888/table?name=UI_SV_FIAS&query=select * from UI_SV_FIAS where C_Full_Address LIKE '%Чеченская%' ORDER BY C_House_Number, C_Full_Address limit 10 my app returns results in more then 10 seconds. But what I need is less then 3 seconds for such query. Does anyone have an idea how can I get that?
Try this: public static JSONArray getResults(Database database, String query) { Cursor cursor = database.rawQuery(query, null); JSONArray resultSet = new JSONArray(); cursor.moveToFirst(); while (!cursor.isAfterLast()) { int totalColumn = cursor.getColumnCount(); JSONObject rowObject = new JSONObject(); for (int i = 0; i < totalColumn; i++) { String columnName = cursor.getColumnName(i); if (columnName != null) { try { String columnValue = cursor.getString(i); if (columnValue != null) { if (isJSONValid(columnValue)) { try { JSONObject object = new JSONObject(columnValue); rowObject.put(columnName, object); }catch (JSONException e){ Logger.error(e); } } else { rowObject.put(columnName, columnValue); } } else { rowObject.put(columnName, ""); } } catch (Exception e) { Logger.error(e); } } } resultSet.put(rowObject); cursor.moveToNext(); } cursor.close(); return resultSet; }
How to get String Array from JSON Object
I am trying to get a list of available numbers from the following json object void doJSONParser(String str) { try { JSONObject order = new JSONObject(str); JSONArray index = order.getJSONArray("webnautes"); for(int i = 0; i < index.length(); i++) { JSONObject tt = index.getJSONObject(i); name += "name: " + tt.getString("name")+"\n"; phone = new String[tt.getString("phone").length()]; //phone += "phone: " + tt.getString("phone")+"\n"; } Log.d("JSON DATA:", name); Log.d("JSON DATA:", phone.toString()); } catch (JSONException e) { e.printStackTrace(); Log.d("JSON ERROR", e.getLocalizedMessage()); } }
Try this JSONArray phoneJson = tt.getJSONArray("phone"); String[] arr = new String[phoneJson.length()]; for(int i = 0; i < phoneJson.length(); i++) arr[i] = phoneJson.getString(i);
Nested JSONArray Record Parsing Issue Android
I am making a App which receives a JSON Data From Server, User will select a value from Spinner like 0,1,2... and so on, On the Basis of number selection JSON will return a data from user defined index like 0,1.. i don't know how to parse a inner JSON Data in Android json = new JSONObject(JSONParser.Result); JSONArray jArray = json.getJSONArray("data"); StopElement _stop = new StopElement(); Log.d("JSON Algo Result", json.toString()); if (jArray!=null) { for (int i = 0; i < jArray.length(); i++) { jsonarray = jArray.getJSONArray(i); if (jsonarray != null) { for (int j = 0; j < jsonarray.length(); i++){ if(i==0) { jsonarray = jArray.getJSONArray(j); _stop.setName(jsonarray.getString(0)); StopElement.Stop_name_list.add(_stop.getName()); } } } else { break; } } } else { return null; } **JSON Data** [[["Sadiqabad Chowk","33.634525","73.074326","suzk1"],["Chungi No 8","33.627262","73.093567","suzk1"],["Jahaz Ground","33.628395","73.101936","suzk1"],["Khana Bridge","33.629967","73.112823","suzk1"],["Kuri Road","33.643162","73.102928","21"],["Faizabad","33.663212","73.084801","21"]],[["Sadiqabad Chowk","33.634525","73.074326","suzk1"],["Petrol Pump","33.634109","73.076363","suzk1"],["Chandni Chowk","33.631584","73.072563","suzk1"],["Rahmanabad","33.639065","73.075714","3"],["Passport Office","33.642410","73.076981","3"],["Shamsabad","33.650101","73.079994","3"],["Faizabad","33.663212","73.084801","3"]],[["Sadiqabad Chowk","33.634525","73.074326","suzk1"],["Chungi No 8","33.627262","73.093567","suzk1"],["Jahaz Ground","33.628395","73.101936","suzk1"],["Khana Bridge","33.629967","73.112823","suzk1"],["Zia Masjid","33.637196","73.107407","124-A"],["Kuri Road","33.643162","73.102928","124-A"],["Dhok Kala Khan","33.653118","73.095444","124-A"],["Faizabad","33.663212","73.084801","124-A"]],[["Sadiqabad Chowk","33.634525","73.074326","suzk1"],["Chungi No 8","33.627262","73.093567","suzk1"],["Jahaz Ground","33.628395","73.101936","suzk1"],["Khana Bridge","33.629967","73.112823","suzk1"],["Zia Masjid","33.637196","73.107407","136"],["Kuri Road","33.643162","73.102928","136"],["Iqbal Town","33.644279","73.100113","136"],["Dhok Kala Khan","33.653118","73.095444","136"],["Faizabad","33.663212","73.084801","136"]],[["Sadiqabad Chowk","33.634525","73.074326","suzk13"],["Dhok Ali Akbar","33.636997","73.092117","suzk13"],["Highway Stop","33.679722","73.075584","suzk13"],["Bhinder","33.556244","73.167946","suzk3"],["Lohi Bher","33.586273","73.145493","124"],["Wild Life Park","33.578770","73.132309","124"],["Airport Chowk","33.593803","73.139938","124"],["Gangal","33.612591","73.125801","124"],["Khana Bridge","33.629967","73.112823","124"],["Zia Masjid","33.637196","73.107407","124"],["Kuri Road","33.643162","73.102928","124"],["Dhok Kala Khan","33.653118","73.095444","124"],["Faizabad","33.663212","73.084801","124"]],[["Sadiqabad Chowk","33.634525","73.074326","suzk13"],["Petrol Pump","33.634109","73.076363","suzk13"],["Chandni Chowk","33.631584","73.072563","suzk13"],["Central Hospital","33.628784","73.070641","suzk13"],["Naz Cinema","33.623936","73.067802","suzk13"],["Waris Khan","33.620728","73.066078","suzk13"],["Comittee Chowk","33.612946","73.065193","suzk13"],["Liaquat Bagh","33.606808","73.064835","suzk13"],["Marir Hassan","33.596905","73.064445","suzk7"],["Punjab House","33.592701","73.065453","suzk7"],["Jhanda","33.588970","73.076195","suzk7"],["Raheemabad","33.599159","73.080048","21"],["Airport","33.603565","73.097137","21"],["Tajabad","33.601593","73.126213","21"],["Koral Chowk","33.605282","73.131279","21"],["Khana Bridge","33.629967","73.112823","21"],["Kuri Road","33.643162","73.102928","21"],["Faizabad","33.663212","73.084801","21"]],[["Sadiqabad Chowk","33.634525","73.074326","suzk13"],["Petrol Pump","33.634109","73.076363","suzk13"],["Chandni Chowk","33.631584","73.072563","suzk13"],["Central Hospital","33.628784","73.070641","suzk13"],["Naz Cinema","33.623936","73.067802","suzk13"],["Waris Khan","33.620728","73.066078","suzk13"],["Comittee Chowk","33.612946","73.065193","suzk13"],["Liaquat Bagh","33.606808","73.064835","suzk13"],["Medical College","33.602753","73.067200","29"],["Sir Syed Boys School","33.609600","73.078766","29"],["Fauji Tower","33.606770","73.084106","29"],["Chaklala Station","33.601013","73.095924","29"],["Raheemabad","33.599159","73.080048","29"],["Airport","33.603565","73.097137","21"],["Tajabad","33.601593","73.126213","21"],["Koral Chowk","33.605282","73.131279","21"],["Khana Bridge","33.629967","73.112823","21"],["Kuri Road","33.643162","73.102928","21"],["Faizabad","33.663212","73.084801","21"]],[["Sadiqabad Chowk","33.634525","73.074326","suzk13"],["Petrol Pump","33.634109","73.076363","suzk13"],["Chandni Chowk","33.631584","73.072563","suzk13"],["Central Hospital","33.628784","73.070641","suzk13"],["Naz Cinema","33.623936","73.067802","suzk13"]]]
this will work definitely for you. String data= "[[['Jahaz Ground','33.628395','73.101936','suzk1'],['Khana Bridge','33.628395','73.101936','suzk1']]]"; try { JSONArray json = new JSONArray(data); JSONArray aray = (JSONArray)json.get(0); for(int i =0; i< aray.length();i++){ JSONArray object = (JSONArray)aray.get(i); String title = (String)object .get(0); String lat = (String)object.get(1); String lng = (String)object.get(2); String com = (String)object.get(3); } } catch (JSONException e) { e.printStackTrace(); }
try this way, U can get result as per your request private String jsonString="[[['Sadiqabad Chowk','33.634525','73.074326','suzk1'],['Chungi No 8','33.627262','73.093567','suzk1'],['Jahaz Ground','33.628395','73.101936','suzk1'],['Khana Bridge','33.629967','73.112823','suzk1'],['Kuri Road','33.643162','73.102928','21'],['Faizabad','33.663212','73.084801','21']],[['Sadiqabad Chowk','33.634525','73.074326','suzk1'],['Petrol Pump','33.634109','73.076363','suzk1'],['Chandni Chowk','33.631584','73.072563','suzk1'],['Rahmanabad','33.639065','73.075714','3'],['Passport Office','33.642410','73.076981','3'],['Shamsabad','33.650101','73.079994','3'],['Faizabad','33.663212','73.084801','3']],[['Sadiqabad Chowk','33.634525','73.074326','suzk1'],['Chungi No 8','33.627262','73.093567','suzk1'],['Jahaz Ground','33.628395','73.101936','suzk1'],['Khana Bridge','33.629967','73.112823','suzk1'],['Zia Masjid','33.637196','73.107407','124-A'],['Kuri Road','33.643162','73.102928','124-A'],['Dhok Kala Khan','33.653118','73.095444','124-A'],['Faizabad','33.663212','73.084801','124-A']],[['Sadiqabad Chowk','33.634525','73.074326','suzk1'],['Chungi No 8','33.627262','73.093567','suzk1'],['Jahaz Ground','33.628395','73.101936','suzk1'],['Khana Bridge','33.629967','73.112823','suzk1'],['Zia Masjid','33.637196','73.107407','136'],['Kuri Road','33.643162','73.102928','136'],['Iqbal Town','33.644279','73.100113','136'],['Dhok Kala Khan','33.653118','73.095444','136'],['Faizabad','33.663212','73.084801','136']],[['Sadiqabad Chowk','33.634525','73.074326','suzk13'],['Dhok Ali Akbar','33.636997','73.092117','suzk13'],['Highway Stop','33.679722','73.075584','suzk13'],['Bhinder','33.556244','73.167946','suzk3'],['Lohi Bher','33.586273','73.145493','124'],['Wild Life Park','33.578770','73.132309','124'],['Airport Chowk','33.593803','73.139938','124'],['Gangal','33.612591','73.125801','124'],['Khana Bridge','33.629967','73.112823','124'],['Zia Masjid','33.637196','73.107407','124'],['Kuri Road','33.643162','73.102928','124'],['Dhok Kala Khan','33.653118','73.095444','124'],['Faizabad','33.663212','73.084801','124']],[['Sadiqabad Chowk','33.634525','73.074326','suzk13'],['Petrol Pump','33.634109','73.076363','suzk13'],['Chandni Chowk','33.631584','73.072563','suzk13'],['Central Hospital','33.628784','73.070641','suzk13'],['Naz Cinema','33.623936','73.067802','suzk13'],['Waris Khan','33.620728','73.066078','suzk13'],['Comittee Chowk','33.612946','73.065193','suzk13'],['Liaquat Bagh','33.606808','73.064835','suzk13'],['Marir Hassan','33.596905','73.064445','suzk7'],['Punjab House','33.592701','73.065453','suzk7'],['Jhanda','33.588970','73.076195','suzk7'],['Raheemabad','33.599159','73.080048','21'],['Airport','33.603565','73.097137','21'],['Tajabad','33.601593','73.126213','21'],['Koral Chowk','33.605282','73.131279','21'],['Khana Bridge','33.629967','73.112823','21'],['Kuri Road','33.643162','73.102928','21'],['Faizabad','33.663212','73.084801','21']],[['Sadiqabad Chowk','33.634525','73.074326','suzk13'],['Petrol Pump','33.634109','73.076363','suzk13'],['Chandni Chowk','33.631584','73.072563','suzk13'],['Central Hospital','33.628784','73.070641','suzk13'],['Naz Cinema','33.623936','73.067802','suzk13'],['Waris Khan','33.620728','73.066078','suzk13'],['Comittee Chowk','33.612946','73.065193','suzk13'],['Liaquat Bagh','33.606808','73.064835','suzk13'],['Medical College','33.602753','73.067200','29'],['Sir Syed Boys School','33.609600','73.078766','29'],['Fauji Tower','33.606770','73.084106','29'],['Chaklala Station','33.601013','73.095924','29'],['Raheemabad','33.599159','73.080048','29'],['Airport','33.603565','73.097137','21'],['Tajabad','33.601593','73.126213','21'],['Koral Chowk','33.605282','73.131279','21'],['Khana Bridge','33.629967','73.112823','21'],['Kuri Road','33.643162','73.102928','21'],['Faizabad','33.663212','73.084801','21']],[['Sadiqabad Chowk','33.634525','73.074326','suzk13'],['Petrol Pump','33.634109','73.076363','suzk13'],['Chandni Chowk','33.631584','73.072563','suzk13'],['Central Hospital','33.628784','73.070641','suzk13'],['Naz Cinema','33.623936','73.067802','suzk13']]]"; private void getJSONResult(String jsonString) { // TODO Auto-generated method stub try { JSONArray jsonArray = new JSONArray(jsonString); // i.e. the JsonMainArray JSONArray JsonInnerArray= (JSONArray)jsonArray.get(0); // i.e. the JsonInnerArray for(int i =0; i< JsonInnerArray.length();i++){ JSONArray jsonObject = (JSONArray)JsonInnerArray.get(i); //i.e. the jsonObject of JsonInnerArray String title = (String)jsonObject .get(0); String latitude = (String)jsonObject.get(1); String longitude = (String)jsonObject.get(2); String companyName = (String)jsonObject.get(3); } } catch (JSONException e) { e.printStackTrace(); } }
I Solved My Issue like this try { int count = 0; if (success == 1) { json = new JSONObject(JSONParser.Result); jArray = json.getJSONArray("data"); StopElement _stop = new StopElement(); for (int i = 0; i < jArray.length(); i++) { count = count + 1; // Log.d("Counter", String.valueOf(count)); get_path.add(String.valueOf(count)); jsonarray = jArray.getJSONArray(i); Log.d("path Array", jsonarray.toString()); if (getitemno>0) { getpath = jArray.getJSONArray(getitemno); for (int j = 0; j < getpath.length(); j++) { getresult = getpath.getJSONArray(j); _stop.setName(getresult.getString(0)); _map.setLat(getresult.getDouble(1)); _map.setLng(getresult.getDouble(2)); StopElement.Stop_name_list.add(_stop.getName()); MapCoordinatesElement.Lat.add(_map.getLat()); MapCoordinatesElement.Lng.add(_map.getLng()); //Log.d("Stop names", _stop.getName()); // Log.d("Index Array", getpath.toString()); } } else { getpath = jArray.getJSONArray(0); for (int j = 0; j < getpath.length(); j++) { getresult = getpath.getJSONArray(j); _stop.setName(getresult.getString(0)); _map.setLat(getresult.getDouble(1)); _map.setLng(getresult.getDouble(2)); StopElement.Stop_name_list.add(_stop.getName()); MapCoordinatesElement.Lat.add(_map.getLat()); MapCoordinatesElement.Lng.add(_map.getLng()); //Log.d("Stop names", _stop.getName()); //Log.d("Index Array", getpath.toString()); } } } // Log.d("Stop names of Algo", StopElement.Stop_name_list.toString()); // Log.d("Index Stop names", StopElement.Stop_name_list.toString()); } catch (JSONException e) { e.printStackTrace(); }
android Cursor to JSONArray
how can I "convert" a Cursor to a JSONArray? my cursor as 3columns (_id, name, birth) I've searched but I can't not find any examples
Cursor to JSONArray public JSONArray cur2Json(Cursor cursor) { JSONArray resultSet = new JSONArray(); cursor.moveToFirst(); while (cursor.isAfterLast() == false) { int totalColumn = cursor.getColumnCount(); JSONObject rowObject = new JSONObject(); for (int i = 0; i < totalColumn; i++) { if (cursor.getColumnName(i) != null) { try { rowObject.put(cursor.getColumnName(i), cursor.getString(i)); } catch (Exception e) { Log.d(TAG, e.getMessage()); } } } resultSet.put(rowObject); cursor.moveToNext(); } cursor.close(); return resultSet; }
private String cursorToString(Cursor crs) { JSONArray arr = new JSONArray(); crs.moveToFirst(); while (!crs.isAfterLast()) { int nColumns = crs.getColumnCount(); JSONObject row = new JSONObject(); for (int i = 0 ; i < nColumns ; i++) { String colName = crs.getColumnName(i); if (colName != null) { String val = ""; try { switch (crs.getType(i)) { case Cursor.FIELD_TYPE_BLOB : row.put(colName, crs.getBlob(i).toString()); break; case Cursor.FIELD_TYPE_FLOAT : row.put(colName, crs.getDouble(i)) ; break; case Cursor.FIELD_TYPE_INTEGER: row.put(colName, crs.getLong(i)) ; break; case Cursor.FIELD_TYPE_NULL : row.put(colName, null) ; break; case Cursor.FIELD_TYPE_STRING : row.put(colName, crs.getString(i)) ; break; } } catch (JSONException e) { } } } arr.put(row); if (!crs.moveToNext()) break; } crs.close(); // close the cursor return arr.toString(); }
You can't convert the contents of a cursor directly into a JSONObject, but you can do that with some logic. for eg: retrieve the Strings from the cursor, form a String which follows the JSON format, and use it to make a json object : JSONObject jFromCursor=new JSONObject(string_in_JSON_format);
Android update sqlite table
I have written Update table using dbAdapter. public void loadDownloadData() { SoapPrimitive responsePrimitiveData; //Loop Table list for (int i = 0; i < tablesName.size(); i++) { try { responsePrimitiveData = soapPrimitiveData(tablesName.get(i)); if (responsePrimitiveData != null) { try { String result = responsePrimitiveData.toString(); JSONObject jsonobject = new JSONObject(result); JSONArray array = jsonobject.getJSONArray("Table1"); int max = array.length(); // Loop each table data for (int j = 0; j < max; j++) { JSONObject obj = array.getJSONObject(j); JSONArray names = obj.names(); StringBuilder strFields = new StringBuilder(); StringBuilder strValues = new StringBuilder(); String[] strToFields = new String[names.length()]; String[] strToFieldsVal = new String[names.length()]; //getting the Json name, values in separate string array for (int k = 0; k < names.length(); k++) { String name = names.getString(k); strToFields[k] = names.getString(k); String strVal; if(obj.getString(name)== null){ strVal=""; strToFieldsVal[k]=""; }else{ if(obj.getString(name).equals(" ")){ strVal=""; strToFieldsVal[k]=""; }else{ String tmp1 = obj.getString(name).replaceAll("\\s+", " "); String tmp = tmp1.replaceAll("\\s+", " "); strVal =tmp.replaceAll("\\s+", " "); strToFieldsVal[k]=strVal; } } strFields.append(name + ","); strValues.append(strVal+","); } //end of json for loop strFields.deleteCharAt(strFields.length() - 1); strValues.deleteCharAt(strValues.length() - 1); if(getTableUpdateType(tablesName.get(i)).equals("1")){ String actualtable = getAndroidTablename(tablesName.get(i)); if(isTableRecords(tablesName.get(i))){ String[] strWhereField = getTablePrimaryKey(tablesName.get(i),strBusinessUnit); String[] strWhereFieldVal = new String[strWhereField.length]; StringBuilder whereFields = new StringBuilder(); for (int a = 0; a < strWhereField.length; a++) { strWhereFieldVal[a] = obj.getString(strWhereField[a]); whereFields.append(strWhereField[a] + "= ? and "); } whereFields.delete(whereFields.length() - 4, whereFields.length()); updateTableRecords(actualtable, strToFields, strToFieldsVal,whereFields.toString() ,strWhereFieldVal); }else{ insertTableRecords(actualtable, strToFields, strToFieldsVal); } }else if(getTableUpdateType(tablesName.get(i)).equals("2")){ }else if(getTableUpdateType(tablesName.get(i)).equals("3")){ }else{ } }//end of each table data } catch (JSONException e) { e.printStackTrace(); } } } catch (IOException e) { e.printStackTrace(); } catch (XmlPullParserException e) { e.printStackTrace(); } } } and I called like update method: public void updateTableRecords(String strTableName, String[] strToFields, String[] strValues,String strWhereField ,String[] strWhereFieldVal){ DBAdapter dbAdapter = DBAdapter.getDBAdapterInstance(DownlaodTableActivity.this); dbAdapter.openDataBase(); ContentValues initialValues = new ContentValues(); for(int i=0 ;i<strToFields.length;i++){ initialValues.put(strToFields[i],strValues[i]); } long n = dbAdapter.updateRecordsInDB(strTableName, initialValues, strWhereField, strWhereFieldVal); System.out.println( " -- n--- " + n); Toast.makeText(DownlaodTableActivity.this, n+" rows updated", Toast.LENGTH_SHORT).show(); } I want to generate update statement dynamic way. From These code I put Where part also.But I did not generate where clause. see : UPDATE strTableName SET ExecutiveCode=?, FreeIssuePrefix=?, DisPaySchedulePrefix=?, NextFreeIssueNo=?, NextReturnNo=?, UploadedType=?, DisNextFOCNo=?, DisNextFreeIssueNo=? Please help me How to give the Where clase(Here I gave String & arguments as string array) Thanks in advance...
try like this dbAdapter.updateRecordsInDB(strTableName, initialValues,""+whereField+"='"+whereFieldValue+"'",null); if your whereField field's type is number then don't use '' If you have to compare with multiple values use String where=""; for(int i=0;i<strWhereField.length();i++) { where=where+whereField[i]+"='"+strWhereFieldValue[i]+"'" if(i<(strWhereField.length()-1)) where=where+" and" } dbAdapter.updateRecordsInDB(strTableName, initialValues,where,null);