Settings

Theme

MySQL 8.0 Labs: JSON aggregation functions

mysqlserverteam.com

57 points by th3sly 9 years ago · 23 comments

Reader

morgo 9 years ago

MySQL Product Manager here.

For a more general overview of 8.0, see: http://mysqlserverteam.com/the-mysql-8-0-0-milestone-release...

This feature is part of the optimizer labs release, which also includes CTEs: http://mysqlserverteam.com/mysql-8-0-labs-recursive-common-t...

  • rubiquity 9 years ago

    Wow! That's a lot of cool stuff! MySQL seems to really be alive lately. Did Oracle decide to give it more attention?

    We're very happy with 5.7 right now and 8.0 looks great. Our app is quite old so invisible indexes will be awesome for finding what we can get rid of.

    When will the JSON and CTEs make it into "proper" MySQL?

  • babyrainbow 9 years ago

    Can MySQL queries refer to a temporary tables more than once in the same query, yet?

    • morgo 9 years ago

      This limitation had to be lifted for CTEs to be reused, which is in the same labs release as the JSON functions mentioned here.

      I haven't checked yet if it is lifted for CTEs only, or all cases. But CTEs are a replacement for most (all?) uses of temporary tables that I can think of.

chrishynes 9 years ago

Very cool!

What about the inverse, going from a JSON array to rows? Perhaps I am dense on the existing MySQL JSON functionality, but I haven't been able to figure that one out.

For example, say I have a JSON array and want to insert a row for each element in the array with its value? The only way I have found is to write a bunch of JSON_EXTRACT(... '$[0]') JSON_EXTRACT(... '$[1]') etc and union them together.

Or, say I have a JSON array and want to GROUP_CONCAT() it to a single comma separated string?

In other words, I know I can do this:

SET @j = '[1, 2, 3]';

SELECT GROUP_CONCAT(JSON_EXTRACT(@j, CONCAT('$[', x.n, ']'))) AS val

  FROM

  (

    SELECT 0 AS n

    UNION

    SELECT 1 AS n

    UNION

    SELECT 2 AS n

    UNION

    SELECT 3 AS n

    UNION

    SELECT 4 AS n

    UNION

    SELECT 5 AS n

  ) x
WHERE x.n < JSON_LENGTH(@j);

But that hurts my eyes. And my heart.

How can I do something like:

SET @j = '[1, 2, 3]';

SELECT GROUP_CONCAT(JSON_EXTRACT(@j, '$[ * ]'))

... and have it concatenate together the values in the array vs. the JSON array itself.

I guess what I'm looking for here is some sort of JSON_SPLIT along the lines of:

SET @j = '[1, 2, 3]';

SELECT GROUP_CONCAT(val) FROM JSON_SPLIT(JSON_EXTRACT(@j, '$[ * ]'), '$')

Which, speaking of, a STRING_SPLIT(val, 'separator') table returning function is also sorely needed.

  • morgo 9 years ago

    It sounds like a JSON_TABLE function: https://docs.oracle.com/database/121/SQLRF/functions092.htm#...

    We are looking to add something similar.

    • chrishynes 9 years ago

      That looks perfect, looking forward to it!

      I was doing a little more research and it looks like MySQL doesn't support table valued functions at all right now -- not built-ins, not custom. I didn't realize that, I guess I just assumed that was a fundamental feature.

      Probably explains the longstanding lack of STRING_SPLIT() etc., I guess.

      Here's hoping you are able to get in a more generic support for table valued functions, including stuff like STRING_SPLIT() as well as custom table returning functions.

ralusek 9 years ago

How is JSON stored/indexed in MySQL?

Is it like JSONB in Postgres with GIN indexing available?

  • morgo 9 years ago

    Here is an example: http://mysqlserverteam.com/indexing-json-documents-via-virtu...

    The optimizer will match JSON expressions to virtual columns w/indexes. So that means you can keep your queries in this form and have them indexed:

    EXPLAIN SELECT * FROM features WHERE feature->"$.properties.STREET" = 'MARKET'\G

    • malisper 9 years ago

      Is there a way to index JSON in MySQL without creating one index per unique field?

      • morgo 9 years ago

        The mapping is not strictly one index per field, but a virtual column expression must map to a MySQL type. So depending on the use-case you may be able to use more complicated expressions to limit indexes.

        But to expand your question, there are two FRs we are looking at:

        1) Inverted (aka FULLTEXT) indexes on JSON documents 2) Multi-value indexes

  • greenlet 9 years ago

    i believe you have to create a virtual column on specific document fields and create a secondary index on that similar to what you do with Postgres' expression indices, I do not think MySQL has a general JSON GIN index yet

greenlet 9 years ago

how does mysql's json type compare to postgres' jsonb? my biggest gripe with both of them is lack of partial update

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection