json数据库哪个读取速度最快,sqlxmljson三种数据库哪种读取速度最快
来源:整理 编辑:黑码技术 2023-09-03 17:50:44
本文目录一览
1,sqlxmljson三种数据库哪种读取速度最快
sql xml json不是数据库, sql是数据查询语言 json xml 一般用来做数据交换格式。mysql sql server,这类才是数据库用一个集合中转,然后将json转list再解析成xml,如果是demo的话有一定限制,因为json解析数据要依据提供的数据的key来解析
2,jsonio和jsonsimple哪个更快
第一,你看看你的json文件是不是放在assets文件夹里;第二,你试试改掉你的json名称,因为你的json名称跟文件夹的名称冲突了,可能会有影响;String s="[0,{\"1\":{\"2\":{\"3\":{\"4\":[5,{\"6\":7}]}}}}]"; Object obj=JSONValue.parse(s); JSONArray array=(JSONArray)obj; System.out.println("======the 2nd element of array======"); System.out.println(array.get(1)); System.o...
3,android json解析三种方式哪种效率最高
用org.json以及谷歌提供gson来解析json数据的方式更好一些。安卓下通常采用以下几种方式解析json数据:1、org.json包(已经集成到android.jar中了)2、google提供的gson库 3、阿里巴巴的fastjson库 4、json-lib以Google出品的Gson为例,具体步骤为:1、首先,从 code.google.com/p/google-gson/downloads/list下载GsonAPI: google-gson-1.7.1-release.zip 把gson-1.7.jar copy到libs(项目根目录新建一个libs文件夹)中。 可以使用以下两种方法解析JSON数据,通过获取JsonReader对象解析JSON数据。代码如下:String jsonData = "[tryJsonReader reader = new JsonReader(new StringReader(jsonData)); reader.beginArray(); while(reader.hasNext())reader.beginObject(); while(reader.hasNext())String tagName = reader.nextName(); if(tagName.equals("username"))System.out.println(reader.nextString()); } else if(tagName.equals("userId"))System.out.println(reader.nextString()); } } reader.endObject(); } reader.endArray(); } catch(Exception e)e.printStackTrace(); } 2、使用Gson对象获取User对象数据进行相应的操作: 代码如下:Type listType = new TypeToken<LinkedList<User>>()Gson gson = new Gson(); LinkedList<User> users = gson.fromJson(jsonData, listType); for (Iterator iterator = users.iterator(); iterator.hasNext();) User user = (User) iterator.next(); System.out.println(user.getUsername()); System.out.println(user.getUserId()); } 3、如果要处理的JSON字符串只包含一个JSON对象,则可以直接使用fromJson获取一个User对象: 代码如下:String jsonData = "Gson gson = new Gson(); User user = gson.fromJson(jsonData, User.class); System.out.println(user.getUsername()); System.out.println(user.getUserId());一、什么是JSON? JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度。 JSON就是一串字符串 只不过元素会使用特定的符号标注。 [] 中括号表示数组 "" 双引号内是属性或值 : 冒号表示后者是前者的值(这个值可以是字符串、数字、也可以是另一个数组或对象) 所以 而[ 当然了,你也可以使用 二、JSON解析之传统的JSON解析 1、生成JSOn字符串 public static String createJsonString(String key, Object value) JSONObject jsonObject = new JSONObject(); jsonObject.put(key, value); return jsonObject.toString(); } 2、解析JSON字符串 分为以下三种情况,一个JavaBean,一个List数组,一个嵌套Map的List数组: import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import org.json.JSONArray; import org.json.JSONObject; import com.android.myjson.domain.Person; /** * 完成对json数据的解析 * */ public class JsonTools public static Person getPerson(String key, String jsonString) Person person = new Person(); try JSONObject jsonObject = new JSONObject(jsonString); JSONObject personObject = jsonObject.getJSONObject("person"); person.setId(personObject.getInt("id")); person.setName(personObject.getString("name")); person.setAddress(personObject.getString("address")); } catch (Exception e) // TODO: handle exception } return person; } public static List getPersons(String key, String jsonString) List list = new ArrayList(); try JSONObject jsonObject = new JSONObject(jsonString); // 返回json的数组 JSONArray jsonArray = jsonObject.getJSONArray(key); for (int i = 0; i < jsonArray.length(); i++) JSONObject jsonObject2 = jsonArray.getJSONObject(i); Person person = new Person(); person.setId(jsonObject2.getInt("id")); person.setName(jsonObject2.getString("name")); person.setAddress(jsonObject2.getString("address")); list.add(person); } } catch (Exception e) // TODO: handle exception } return list; } public static List getList(String key, String jsonString) List list = new ArrayList(); try JSONObject jsonObject = new JSONObject(jsonString); JSONArray jsonArray = jsonObject.getJSONArray(key); for (int i = 0; i < jsonArray.length(); i++) String msg = jsonArray.getString(i); list.add(msg); } } catch (Exception e) // TODO: handle exception } return list; } public static List> listKeyMaps(String key, String jsonString) List> list = new ArrayList>(); try JSONObject jsonObject = new JSONObject(jsonString); JSONArray jsonArray = jsonObject.getJSONArray(key); for (int i = 0; i < jsonArray.length(); i++) JSONObject jsonObject2 = jsonArray.getJSONObject(i); Map map = new HashMap(); Iterator iterator = jsonObject2.keys(); while (iterator.hasNext()) String json_key = iterator.next(); Object json_value = jsonObject2.get(json_key); if (json_value == null) json_value = ""; } map.put(json_key, json_value); } list.add(map); } } catch (Exception e) // TODO: handle exception } return list; } },>,>三、JSON解析之GSON 1、生成JSON字符串 import com.google.gson.Gson; public class JsonUtils public static String createJsonObject(Object obj) Gson gson = new Gson(); String str = gson.toJson(obj); return str; } }二、解析JSON import java.util.ArrayList; import java.util.List; import java.util.Map; import com.google.gson.Gson; import com.google.gson.reflect.TypeToken; ; public class GsonTools public GsonTools() // TODO Auto-generated constructor stub } /** * @param * @param jsonString * @param cls * @return */ public static T getPerson(String jsonString, Class cls) T t = null; try Gson gson = new Gson(); t = gson.fromJson(jsonString, cls); } catch (Exception e) // TODO: handle exception } return t; } /** * 使用Gson进行解析 List * * @param * @param jsonString * @param cls * @return */ public static List getPersons(String jsonString, Class cls) List list = new ArrayList(); try Gson gson = new Gson(); list = gson.fromJson(jsonString, new TypeToken>() }.getType()); } catch (Exception e) } return list; } /** * @param jsonString * @return */ public static List getList(String jsonString) List list = new ArrayList(); try Gson gson = new Gson(); list = gson.fromJson(jsonString, new TypeToken>() }.getType()); } catch (Exception e) // TODO: handle exception } return list; } public static List> listKeyMaps(String jsonString) List> list = new ArrayList>(); try Gson gson = new Gson(); list = gson.fromJson(jsonString, new TypeToken>>() }.getType()); } catch (Exception e) // TODO: handle exception } return list; } } 三、JSON解析之FastJSON import java.util.ArrayList; import java.util.List; import java.util.Map; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.TypeReference; public class JsonTool public static T getPerson(String jsonstring, Class cls) T t = null; try t = JSON.parseObject(jsonstring, cls); } catch (Exception e) // TODO: handle exception } return t; } public static List getPersonList(String jsonstring, Class cls) List list = new ArrayList(); try list = JSON.parseArray(jsonstring, cls); } catch (Exception e) // TODO: handle exception } return list; } public static List> getPersonListMap1( String jsonstring) List> list = new ArrayList>(); try list = JSON.parseObject(jsonstring, new TypeReference>>() }.getType()); } catch (Exception e) // TODO: handle exception } return list; } } 总结: JSON对于移动设备来说,尤其对于网络环境较差和流量限制的情况下,相对于XML格式的数据传输会更节省流量,传输效率更高。在这三种解析方式中FastJson是效率最高的,推荐使用。转载简单的给你做了下解析,具体要解析到什么程度,你自己看吧。大概解析方法就是这样的:如下:privatevoid testjson()string jsondata = "[jsonobject obj = null;jsonarray jsonarary;try jsonarary = new jsonarray(jsondata);for(int i=0;iobj = jsonarary.getjsonobject(i); //取id jsonarray strid = obj.getjsonarray("id"); for(int j=0;j log.v("id:", strid.get(j).tostring()); } //取num jsonarray strnum = obj.getjsonarray("num"); for(int k=0;k log.v("num:", strnum.get(k).tostring()); } } } catch (jsonexception e) { e.printstacktrace(); }
文章TAG:
数据 数据库 哪个 读取 json数据库哪个读取速度最快