Skip to content

/AWS1/IF_DZN=>QUERYGRAPH()

About QueryGraph

Queries entities in the graph store.

Method Signature

METHODS /AWS1/IF_DZN~QUERYGRAPH
  IMPORTING
    !IV_DOMAINIDENTIFIER TYPE /AWS1/DZNDOMAINID OPTIONAL
    !IT_MATCH TYPE /AWS1/CL_DZNMATCHCLAUSE=>TT_MATCHCLAUSES OPTIONAL
    !IV_MAXRESULTS TYPE /AWS1/DZNMAXRESULTS OPTIONAL
    !IV_NEXTTOKEN TYPE /AWS1/DZNPAGINATIONTOKEN OPTIONAL
    !IO_ADDITIONALATTRIBUTES TYPE REF TO /AWS1/CL_DZNADDLATTRIBUTES OPTIONAL
  RETURNING
    VALUE(OO_OUTPUT) TYPE REF TO /aws1/cl_dznquerygraphoutput
  RAISING
    /AWS1/CX_DZNACCESSDENIEDEX
    /AWS1/CX_DZNTHROTTLINGEX
    /AWS1/CX_DZNUNAUTHORIZEDEX
    /AWS1/CX_DZNINTERNALSERVEREX
    /AWS1/CX_DZNVALIDATIONEX
    /AWS1/CX_DZNCLIENTEXC
    /AWS1/CX_DZNSERVEREXC
    /AWS1/CX_RT_TECHNICAL_GENERIC
    /AWS1/CX_RT_SERVICE_GENERIC.

IMPORTING

Required arguments:

iv_domainidentifier TYPE /AWS1/DZNDOMAINID /AWS1/DZNDOMAINID

The identifier of the Amazon DataZone domain.

it_match TYPE /AWS1/CL_DZNMATCHCLAUSE=>TT_MATCHCLAUSES TT_MATCHCLAUSES

List of query match clauses.

Optional arguments:

iv_maxresults TYPE /AWS1/DZNMAXRESULTS /AWS1/DZNMAXRESULTS

The maximum number of entities to return in a single call to QueryGraph. When the number of entities to be listed is greater than the value of MaxResults, the response contains a NextToken value that you can use in a subsequent call to QueryGraph to list the next set of entities.

iv_nexttoken TYPE /AWS1/DZNPAGINATIONTOKEN /AWS1/DZNPAGINATIONTOKEN

When the number of entities is greater than the default value for the MaxResults parameter, or if you explicitly specify a value for MaxResults that is less than the number of entities, the response includes a pagination token named NextToken. You can specify this NextToken value in a subsequent call to QueryGraph to list the next set of entities.

io_additionalattributes TYPE REF TO /AWS1/CL_DZNADDLATTRIBUTES /AWS1/CL_DZNADDLATTRIBUTES

Additional details on the queried entity that can be requested in the response.

RETURNING

oo_output TYPE REF TO /aws1/cl_dznquerygraphoutput /AWS1/CL_DZNQUERYGRAPHOUTPUT

Examples

Syntax Example

This is an example of the syntax for calling the method. It includes every possible argument and initializes every possible value. The data provided is not necessarily semantically accurate (for example the value "string" may be provided for something that is intended to be an instance ID, or in some cases two arguments may be mutually exclusive). The syntax shows the ABAP syntax for creating the various data structures.

DATA(lo_result) = lo_client->querygraph(
  io_additionalattributes = new /aws1/cl_dznaddlattributes(
    it_formnames = VALUE /aws1/cl_dznformnamelist_w=>tt_formnamelist(
      ( new /aws1/cl_dznformnamelist_w( |string| ) )
    )
  )
  it_match = VALUE /aws1/cl_dznmatchclause=>tt_matchclauses(
    (
      new /aws1/cl_dznmatchclause(
        io_entitypattern = new /aws1/cl_dznentitypattern(
          io_filters = new /aws1/cl_dznfilterclause(
            io_filter = new /aws1/cl_dznfilter(
              iv_attribute = |string|
              iv_intvalue = 123
              iv_operator = |string|
              iv_value = |string|
            )
            it_and = VALUE /aws1/cl_dznfilterclause=>tt_filterlist(
              (
                new /aws1/cl_dznfilterclause(
                  io_filter = new /aws1/cl_dznfilter(
                    iv_attribute = |string|
                    iv_intvalue = 123
                    iv_operator = |string|
                    iv_value = |string|
                  )
                  it_or = VALUE /aws1/cl_dznfilterclause=>tt_filterlist(
                  )
                )
              )
            )
            it_or = VALUE /aws1/cl_dznfilterclause=>tt_filterlist(
              (
                new /aws1/cl_dznfilterclause(
                  io_filter = new /aws1/cl_dznfilter(
                    iv_attribute = |string|
                    iv_intvalue = 123
                    iv_operator = |string|
                    iv_value = |string|
                  )
                  it_and = VALUE /aws1/cl_dznfilterclause=>tt_filterlist(
                  )
                )
              )
            )
          )
          iv_entitytype = |string|
          iv_identifier = |string|
        )
        io_relationpattern = new /aws1/cl_dznrelationpattern(
          iv_maxpathlength = 123
          iv_relationdirection = |string|
          iv_relationtype = |string|
        )
      )
    )
  )
  iv_domainidentifier = |string|
  iv_maxresults = 123
  iv_nexttoken = |string|
).

This is an example of reading all possible response values

lo_result = lo_result.
IF lo_result IS NOT INITIAL.
  LOOP AT lo_result->get_items( ) into lo_row.
    lo_row_1 = lo_row.
    IF lo_row_1 IS NOT INITIAL.
      lo_lineagenodeitem = lo_row_1->get_lineagenode( ).
      IF lo_lineagenodeitem IS NOT INITIAL.
        lv_domainid = lo_lineagenodeitem->get_domainid( ).
        lv_string = lo_lineagenodeitem->get_name( ).
        lv_string = lo_lineagenodeitem->get_description( ).
        lv_createdat = lo_lineagenodeitem->get_createdat( ).
        lv_createdby = lo_lineagenodeitem->get_createdby( ).
        lv_updatedat = lo_lineagenodeitem->get_updatedat( ).
        lv_updatedby = lo_lineagenodeitem->get_updatedby( ).
        lv_lineagenodeid = lo_lineagenodeitem->get_id( ).
        lv_string = lo_lineagenodeitem->get_typename( ).
        lv_revision = lo_lineagenodeitem->get_typerevision( ).
        lv_string = lo_lineagenodeitem->get_sourceidentifier( ).
        lv_timestamp = lo_lineagenodeitem->get_eventtimestamp( ).
        LOOP AT lo_lineagenodeitem->get_formsoutput( ) into lo_row_2.
          lo_row_3 = lo_row_2.
          IF lo_row_3 IS NOT INITIAL.
            lv_formname = lo_row_3->get_formname( ).
            lv_formtypename = lo_row_3->get_typename( ).
            lv_revision = lo_row_3->get_typerevision( ).
            lv_string = lo_row_3->get_content( ).
          ENDIF.
        ENDLOOP.
        LOOP AT lo_lineagenodeitem->get_upstreamlineagenodeids( ) into lo_row_4.
          lo_row_5 = lo_row_4.
          IF lo_row_5 IS NOT INITIAL.
            lv_lineagenodeid = lo_row_5->get_value( ).
          ENDIF.
        ENDLOOP.
        LOOP AT lo_lineagenodeitem->get_downstreamlineagenodeids( ) into lo_row_4.
          lo_row_5 = lo_row_4.
          IF lo_row_5 IS NOT INITIAL.
            lv_lineagenodeid = lo_row_5->get_value( ).
          ENDIF.
        ENDLOOP.
      ENDIF.
    ENDIF.
  ENDLOOP.
  lv_paginationtoken = lo_result->get_nexttoken( ).
ENDIF.