Functions for structures

    Arguments:

    1. Structure.
    2. Field name.
    3. Default value.

    ExpandStruct

    Adding one or more new fields to the structure.

    If the field set contains duplicate values, an error is returned.

    Arguments:

    • The first argument passes the source structure to be expanded.
    • All the other arguments must be named, each argument adds a new field and the argument’s name is used as the field’s name (as in ).

    Examples

    1. SELECT
    2. ExpandStruct(
    3. 2 AS b,
    4. "3" AS c
    5. ) AS abc;

    For structures - 图2

    AddMember

    Adding one new field to the structure. If you need to add multiple fields, better use .

    If the field set contains duplicate values, an error is returned.

    Arguments:

    1. Source structure.
    2. Name of the new field.
    3. Value of the new field.

    Examples

    1. $struct = <|a:1|>;
    2. SELECT
    3. AddMember(
    4. $struct,
    5. "b",
    6. 2
    7. ) AS ab;

    RemoveMember

    Removing a field from the structure.

    If the entered field hasn’t existed, an error is returned.

    Arguments:

    1. Source structure.
    2. Field name.

    Examples

    1. $struct = <|a:1, b:2|>;
    2. SELECT
    3. RemoveMember(
    4. $struct,
    5. "b"
    6. ) AS a;

    For structures - 图4

    ForceRemoveMember

    Removing a field from the structure.

    If the entered field hasn’t existed, unlike RemoveMember, the error is not returned.

    Arguments:

    1. Source structure.
    2. Field name.

    Examples

    1. $struct = <|a:1, b:2|>;
    2. SELECT
    3. ForceRemoveMember(
    4. $struct,
    5. ) AS ab;

    Selecting fields with specified names from the structure.

    Arguments:

    1. Source structure.
    2. List of field names.

    Examples

    For structures - 图6

    RemoveMembers

    Excluding fields with specified names from the structure.

    If any of the fields haven’t existed, an error is returned.

    Arguments:

    1. Source structure.
    2. List of field names.

    Examples

    1. $struct = <|a:1, b:2, c:3|>;
    2. SELECT
    3. RemoveMembers(
    4. $struct,
    5. ["a", "b"]
    6. ) AS c;

    ForceRemoveMembers

    Excluding fields with specified names from the structure.

    If any of the fields haven’t existed, it is ignored.

    Arguments:

    1. Source structure.

    Examples

    1. $struct = <|a:1, b:2, c:3|>;
    2. SELECT
    3. ForceRemoveMembers(
    4. $struct,
    5. ["a", "b", "z"]
    6. ) AS c;

    For structures - 图8

    CombineMembers

    Combining the fields from multiple structures into a new structure.

    If the resulting field set contains duplicate values, an error is returned.

    Arguments: two or more structures.

    Examples

    1. $struct1 = <|a:1, b:2|>;
    2. $struct2 = <|c:3|>;
    3. SELECT
    4. CombineMembers(
    5. $struct1,
    6. $struct2
    7. ) AS abc;

    FlattenMembers

    Combining the fields from multiple new structures into another new structure with prefix support.

    If the resulting field set contains duplicate values, an error is returned.

    Arguments: two or more tuples of two items: prefix and structure.

    Examples

    1. $struct1 = <|a:1, b:2|>;
    2. $struct2 = <|c:3|>;
    3. SELECT
    4. AsTuple("foo", $struct1), -- fooa, foob
    5. AsTuple("bar", $struct2) -- barc
    6. ) AS abc;

    For structures - 图10

    Argument: structure

    Examples

    RenameMembers

    Renames the fields in the structure passed. In this case, you can rename a source field into multiple target fields. All fields not mentioned in the renaming as source names are moved to the result structure. If some source field is omitted in the rename list, an error is returned. For an Optional structure or NULL, the result has the same type.

    Arguments:

    1. Source structure.
    2. A tuple of field names: the original name, the new name.

    Examples

    1. $struct = <|a:1, b:2|>;
    2. SELECT
    3. RenameMembers($struct, [('a', 'c'), ('a', 'e')]); -- (b:2, c:1, e:1)

    For structures - 图12

    ForceRenameMembers

    Renames the fields in the structure passed. In this case, you can rename a source field into multiple target fields. All fields not mentioned in the renaming as source names are moved to the result structure. If some source field is omitted in the rename list, the name is ignored. For an Optional structure or NULL, the result has the same type.

    Arguments:

    1. Source structure.
    2. A tuple of field names: the original name, the new name.

    Examples

    1. $struct = <|a:1, b:2|>;
    2. SELECT
    3. ForceRenameMembers($struct, [('a', 'c'), ('d', 'e')]); -- (b:2, c:1)

    GatherMembers

    Returns an unordered list of tuples including the field name and value. For the NULL argument, EmptyList is returned. It can be used only in the cases when the types of items in the structure are the same or compatible. Returns an optional list for an optional structure.

    Argument: structure

    Examples

    1. $struct = <|a:1, b:2|>;
    2. SELECT
    3. GatherMembers($struct); -- [('a', 1), ('b', 2)]

    For structures - 图14

    SpreadMembers

    Creates a structure with a specified list of fields and applies a specified list of edits to it in the format (field name, field value). All types of fields in the resulting structure are the same and equal to the type of values in the update list with added Optional (unless they are optional already). If the field wasn’t mentioned among the list of updated fields, it’s returned as NULL. Among all updates for a field, the latest one is written. If the update list is Optional or NULL, the result has the same type. If the list of edits includes a field that is not in the list of expected fields, an error is returned.

    Arguments:

    1. List of tuples: field name, field value.
    2. A list of all possible field names in the structure.

    Examples

    1. SELECT
    2. SpreadMembers([('a',1),('a',2)],['a','b']); -- (a: 2, b: null)

    Creates a structure with a specified list of fields and applies to it the specified list of updates in the format (field name, field value). All types of fields in the resulting structure are the same and equal to the type of values in the update list with added Optional (unless they are optional already). If the field wasn’t mentioned among the list of updated fields, it’s returned as NULL. Among all updates for a field, the latest one is written. If the update list is optional or equal to , the result has the same type. If the list of updates includes a field that is not in the list of expected fields, this edit is ignored.

    Arguments:

    1. List of tuples: field name, field value.
    2. A list of all possible field names in the structure.

    Examples

    For structures - 图16