数据库解析json,数据库解析兼容zip和rar

发布时间:2023-12-08

数据库解析json,数据库解析兼容zip和rar

更新:<time datetime="2022-11-20 23:15">2022-11-20 23:15</time>

本文目录一览:

  1. 求一个数据库函数解析json 如下图要求
  2. json数据解析出错应该怎么办?
  3. 如何解析返回的json格式数据

求一个数据库函数解析json 如下图要求

数据库只是用来存储数据的,为什么不把处理数据的部分放在后台? 在这里你需要了解以下几个知识点。 在sqlserver 中存储json ,需要用字符串类型进行存储,一般用nvarchar()或 varchar()进行存储。

  • openJson: 打开Json字符串
  • IsJson: 判断一个字符串是不是合法的Json格式。是返回1,否返回0,null返回null。
  • Json_Value: 从Json字符串中提取值。
  • Json_Query: Json字符串中提取对象或数组。
  • Json_Modify: 更新Json字符串中的属性值,并返回更新的Json字符串
    然后参考图片的需求,获取输入key值中的value字段可以得到如下sql语句。 从JSON中获取输入B的JSON对象
SELECT JSON_QUERY(json, CONCAT('$.',key)) INTO K_VAL;

从B的JSON对象中,获取value字段的值

SELECT JSON_VALUE(K_VAL, '$.value') INTO JSONVALUE;

最终我们的声明的函数大概是:

CREATE FUNCTION PARSEJSON(json VARCHAR(2000), key VARCHAR(200))
RETURNS VARCHAR
BEGIN
    declare JSONVALUE VARCHAR;
    declare K_VAL VARCHAR;
    SELECT JSON_QUERY(json, CONCAT('$.',key)) INTO K_VAL;
    SELECT JSON_VALUE(K_VAL, '$.value') INTO JSONVALUE;
    return JSONVALUE;
END

json数据解析出错应该怎么办?

JSON数据解析错误处理办法如下:

  • JSONValue failed. Error is: Unescaped control character [0x0D]
    这个错误就是JSON解析的时候String 的时候出现转义字符。 对应用NSString里的stringByReplacingOccurrencesOfString:@"\r" withString:@""取消掉转义字符就OK那!
NSString *json_string1 = [json_string stringByReplacingOccurrencesOfString:@"\r" withString:@""];

或者是在线工具生成的代码,并不能保证百分百准确的。

如何解析返回的json格式数据

json数据格式解析我自己分为两种: 一种是普通的,一种是带有数组形式的;

普通形式的:

服务器端返回的json数据格式如下:

{
  "userbean": {
    "Uid": "100196",
    "Showname": "\u75af\u72c2\u7684\u7334\u5b50",
    "Avtar": null,
    "State": 1
  }
}

分析代码如下:

// TODO 状态处理 500 200
int res = 0;
res = httpClient.execute(httpPost).getStatusLine().getStatusCode();
if (res == 200) {
    /*
     * 当返回码为200时,做处理
     * 得到服务器端返回json数据,并做处理
     * */
    HttpResponse httpResponse = httpClient.execute(httpPost);
    StringBuilder builder = new StringBuilder();
    BufferedReader bufferedReader2 = new BufferedReader(
        new InputStreamReader(httpResponse.getEntity().getContent()));
    String str2 = "";
    for (String s = bufferedReader2.readLine(); s != null; s = bufferedReader2.readLine()) {
        builder.append(s);
    }
    Log.i("cat", "" + builder.toString());
    JSONObject jsonObject = new JSONObject(builder.toString()).getJSONObject("userbean");
    String Uid;
    String Showname;
    String Avtar;
    String State;
    Uid = jsonObject.getString("Uid");
    Showname = jsonObject.getString("Showname");
    Avtar = jsonObject.getString("Avtar");
    State = jsonObject.getString("State");
}

带数组形式的:

服务器端返回的数据格式为:

{
  "calendar": {
    "calendarlist": [
      {
        "calendar_id": "1705",
        "title": "(\u4eb2\u5b50)ddssd",
        "category_name": "\u9ed8\u8ba4\u5206\u7c7b",
        "showtime": "1288927800",
        "endshowtime": "1288931400",
        "allDay": false
      },
      {
        "calendar_id": "1706",
        "title": "(\u65c5\u884c)",
        "category_name": "\u9ed8\u8ba4\u5206\u7c7b",
        "showtime": "1288933200",
        "endshowtime": "1288936800",
        "allDay": false
      }
    ]
  }
}

分析代码如下:

// TODO 状态处理 500 200
int res = 0;
res = httpClient.execute(httpPost).getStatusLine().getStatusCode();
if (res == 200) {
    /*
     * 当返回码为200时,做处理
     * 得到服务器端返回json数据,并做处理
     * */
    HttpResponse httpResponse = httpClient.execute(httpPost);
    StringBuilder builder = new StringBuilder();
    BufferedReader bufferedReader2 = new BufferedReader(
        new InputStreamReader(httpResponse.getEntity().getContent()));
    String str2 = "";
    for (String s = bufferedReader2.readLine(); s != null; s = bufferedReader2.readLine()) {
        builder.append(s);
    }
    Log.i("cat", "" + builder.toString());
    /**
     * 这里需要分析服务器回传的json格式数据,
     */
    JSONObject jsonObject = new JSONObject(builder.toString()).getJSONObject("calendar");
    JSONArray jsonArray = jsonObject.getJSONArray("calendarlist");
    for (int i = 0; i < jsonArray.length(); i++) {
        JSONObject jsonObject2 = (JSONObject) jsonArray.opt(i);
        CalendarInfo calendarInfo = new CalendarInfo();
        calendarInfo.setCalendar_id(jsonObject2.getString("calendar_id"));
        calendarInfo.setTitle(jsonObject2.getString("title"));
        calendarInfo.setCategory_name(jsonObject2.getString("category_name"));
        calendarInfo.setShowtime(jsonObject2.getString("showtime"));
        calendarInfo.setEndtime(jsonObject2.getString("endshowtime"));
        calendarInfo.setAllDay(jsonObject2.getBoolean("allDay"));
        calendarInfos.add(calendarInfo);
    }
}

总结,普通形式的只需用JSONObject,带数组形式的需要使用JSONArray将其变成一个list。