diff options
author | Alexey Botchkov <holyfoot@askmonty.org> | 2017-11-16 19:59:27 +0400 |
---|---|---|
committer | Alexey Botchkov <holyfoot@askmonty.org> | 2017-11-16 19:59:27 +0400 |
commit | 842dce378aae168a339fc8d789e3e395903aeb26 (patch) | |
tree | b57b85bc1754fd2df09a5ab99ef1fd161b9aa257 /sql/item_jsonfunc.cc | |
parent | 0c4d11e8199f4c7a9e41fc3f86819219c21ddc4d (diff) | |
download | mariadb-git-842dce378aae168a339fc8d789e3e395903aeb26.tar.gz |
MDEV-14402 JSON_VALUE doesn't escape quote.
Result unescaping added.
Diffstat (limited to 'sql/item_jsonfunc.cc')
-rw-r--r-- | sql/item_jsonfunc.cc | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/sql/item_jsonfunc.cc b/sql/item_jsonfunc.cc index 9493d75018d..ff062b81a2e 100644 --- a/sql/item_jsonfunc.cc +++ b/sql/item_jsonfunc.cc @@ -69,6 +69,7 @@ static inline bool append_simple(String *s, const uchar *a, size_t a_len) /* Appends JSON string to the String object taking charsets in consideration. +*/ static int st_append_json(String *s, CHARSET_INFO *json_cs, const uchar *js, uint js_len) { @@ -82,9 +83,8 @@ static int st_append_json(String *s, return 0; } - return js_len; + return str_len; } -*/ /* @@ -475,6 +475,9 @@ String *Item_func_json_value::val_str(String *str) json_scan_start(&je, js->charset(),(const uchar *) js->ptr(), (const uchar *) js->ptr() + js->length()); + str->length(0); + str->set_charset(&my_charset_utf8mb4_bin); + path.cur_step= path.p.steps; continue_search: if (json_find_path(&je, &path.p, &path.cur_step, array_counters)) @@ -515,8 +518,7 @@ bool Item_func_json_value::check_and_get_value(json_engine_t *je, String *res, return true; } - res->set((const char *) je->value, je->value_len, je->s.cs); - return false; + return st_append_json(res, je->s.cs, je->value, je->value_len); } |