Using cross apply to query nested arrays in json












2















I have what is probably a relatively easy query but I cannot get my head around how to query nested json arrays. I have a SQL 2016 DB with a json field which contains a json string with multiple child arrays.



Attached is an image of the json data:



enter image description here



I would like to query the "identification" data (99999829250103)



I can query data such as the accountId (LOADACC001) or nickname (LoadTest) using the following query but cannot query from the "account" array:



   SELECT top 1
accountId as NonUserAccountId
FROM [DBName].DBSchema.transactions t
CROSS APPLY OPENJSON (t.BankDataText, N'$.data')
WITH
(
accountId VARCHAR(100) 'strict $.account.accountId'
)
where t.Id = 675


The field 'BankDataText' contains the json string and the table is called 'transactions'. when I add another CROSS APPLY to the query no rows are returned.










share|improve this question

























  • Please post the entire json in a textual (non-image) format

    – Andrea
    Jan 3 at 12:49
















2















I have what is probably a relatively easy query but I cannot get my head around how to query nested json arrays. I have a SQL 2016 DB with a json field which contains a json string with multiple child arrays.



Attached is an image of the json data:



enter image description here



I would like to query the "identification" data (99999829250103)



I can query data such as the accountId (LOADACC001) or nickname (LoadTest) using the following query but cannot query from the "account" array:



   SELECT top 1
accountId as NonUserAccountId
FROM [DBName].DBSchema.transactions t
CROSS APPLY OPENJSON (t.BankDataText, N'$.data')
WITH
(
accountId VARCHAR(100) 'strict $.account.accountId'
)
where t.Id = 675


The field 'BankDataText' contains the json string and the table is called 'transactions'. when I add another CROSS APPLY to the query no rows are returned.










share|improve this question

























  • Please post the entire json in a textual (non-image) format

    – Andrea
    Jan 3 at 12:49














2












2








2


0






I have what is probably a relatively easy query but I cannot get my head around how to query nested json arrays. I have a SQL 2016 DB with a json field which contains a json string with multiple child arrays.



Attached is an image of the json data:



enter image description here



I would like to query the "identification" data (99999829250103)



I can query data such as the accountId (LOADACC001) or nickname (LoadTest) using the following query but cannot query from the "account" array:



   SELECT top 1
accountId as NonUserAccountId
FROM [DBName].DBSchema.transactions t
CROSS APPLY OPENJSON (t.BankDataText, N'$.data')
WITH
(
accountId VARCHAR(100) 'strict $.account.accountId'
)
where t.Id = 675


The field 'BankDataText' contains the json string and the table is called 'transactions'. when I add another CROSS APPLY to the query no rows are returned.










share|improve this question
















I have what is probably a relatively easy query but I cannot get my head around how to query nested json arrays. I have a SQL 2016 DB with a json field which contains a json string with multiple child arrays.



Attached is an image of the json data:



enter image description here



I would like to query the "identification" data (99999829250103)



I can query data such as the accountId (LOADACC001) or nickname (LoadTest) using the following query but cannot query from the "account" array:



   SELECT top 1
accountId as NonUserAccountId
FROM [DBName].DBSchema.transactions t
CROSS APPLY OPENJSON (t.BankDataText, N'$.data')
WITH
(
accountId VARCHAR(100) 'strict $.account.accountId'
)
where t.Id = 675


The field 'BankDataText' contains the json string and the table is called 'transactions'. when I add another CROSS APPLY to the query no rows are returned.







sql json sql-server tsql sql-server-2016






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Jan 4 at 10:52









Andrea

7,751144854




7,751144854










asked Jan 2 at 13:24









SilverESilverE

163




163













  • Please post the entire json in a textual (non-image) format

    – Andrea
    Jan 3 at 12:49



















  • Please post the entire json in a textual (non-image) format

    – Andrea
    Jan 3 at 12:49

















Please post the entire json in a textual (non-image) format

– Andrea
Jan 3 at 12:49





Please post the entire json in a textual (non-image) format

– Andrea
Jan 3 at 12:49












1 Answer
1






active

oldest

votes


















1














You are on the right track, you just need to extract the nested json section with as json and then use another cross apply with open json to read the inner account section:



declare @tmp table ([id] int, BankDataText nvarchar(max))
declare @j nvarchar(max)='{
"data": [{
"account": {
"account": [{
"schemaName": "SortCodeAccountNumber",
"identification": "99999829250103",
"name": "Load testing ....",
"secondaryIdentification": "123456789"
}],
"accountType": "null",
"accountSubType": "null",
"description": null,
"accountId": "LOADACC001",
"currency": "GBP",
"nickname": "LoadTest",
"servicer": {
"schemaName": "BICFI",
"identification": "PAPAUK00XXX"
}
}
}]
}'
insert into @tmp select 675, @j

select top 1
A.accountId as NonUserAccountId, B.identification
from @tmp t
cross apply openjson (t.BankDataText, N'$.data') with
(
accountId varchar(100) 'strict $.account.accountId',
account nvarchar(max) 'strict $.account.account' as json
) A
cross apply openjson(A.account) with
(
identification varchar(100)
) B


Result:



enter image description here






share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54007182%2fusing-cross-apply-to-query-nested-arrays-in-json%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    1














    You are on the right track, you just need to extract the nested json section with as json and then use another cross apply with open json to read the inner account section:



    declare @tmp table ([id] int, BankDataText nvarchar(max))
    declare @j nvarchar(max)='{
    "data": [{
    "account": {
    "account": [{
    "schemaName": "SortCodeAccountNumber",
    "identification": "99999829250103",
    "name": "Load testing ....",
    "secondaryIdentification": "123456789"
    }],
    "accountType": "null",
    "accountSubType": "null",
    "description": null,
    "accountId": "LOADACC001",
    "currency": "GBP",
    "nickname": "LoadTest",
    "servicer": {
    "schemaName": "BICFI",
    "identification": "PAPAUK00XXX"
    }
    }
    }]
    }'
    insert into @tmp select 675, @j

    select top 1
    A.accountId as NonUserAccountId, B.identification
    from @tmp t
    cross apply openjson (t.BankDataText, N'$.data') with
    (
    accountId varchar(100) 'strict $.account.accountId',
    account nvarchar(max) 'strict $.account.account' as json
    ) A
    cross apply openjson(A.account) with
    (
    identification varchar(100)
    ) B


    Result:



    enter image description here






    share|improve this answer




























      1














      You are on the right track, you just need to extract the nested json section with as json and then use another cross apply with open json to read the inner account section:



      declare @tmp table ([id] int, BankDataText nvarchar(max))
      declare @j nvarchar(max)='{
      "data": [{
      "account": {
      "account": [{
      "schemaName": "SortCodeAccountNumber",
      "identification": "99999829250103",
      "name": "Load testing ....",
      "secondaryIdentification": "123456789"
      }],
      "accountType": "null",
      "accountSubType": "null",
      "description": null,
      "accountId": "LOADACC001",
      "currency": "GBP",
      "nickname": "LoadTest",
      "servicer": {
      "schemaName": "BICFI",
      "identification": "PAPAUK00XXX"
      }
      }
      }]
      }'
      insert into @tmp select 675, @j

      select top 1
      A.accountId as NonUserAccountId, B.identification
      from @tmp t
      cross apply openjson (t.BankDataText, N'$.data') with
      (
      accountId varchar(100) 'strict $.account.accountId',
      account nvarchar(max) 'strict $.account.account' as json
      ) A
      cross apply openjson(A.account) with
      (
      identification varchar(100)
      ) B


      Result:



      enter image description here






      share|improve this answer


























        1












        1








        1







        You are on the right track, you just need to extract the nested json section with as json and then use another cross apply with open json to read the inner account section:



        declare @tmp table ([id] int, BankDataText nvarchar(max))
        declare @j nvarchar(max)='{
        "data": [{
        "account": {
        "account": [{
        "schemaName": "SortCodeAccountNumber",
        "identification": "99999829250103",
        "name": "Load testing ....",
        "secondaryIdentification": "123456789"
        }],
        "accountType": "null",
        "accountSubType": "null",
        "description": null,
        "accountId": "LOADACC001",
        "currency": "GBP",
        "nickname": "LoadTest",
        "servicer": {
        "schemaName": "BICFI",
        "identification": "PAPAUK00XXX"
        }
        }
        }]
        }'
        insert into @tmp select 675, @j

        select top 1
        A.accountId as NonUserAccountId, B.identification
        from @tmp t
        cross apply openjson (t.BankDataText, N'$.data') with
        (
        accountId varchar(100) 'strict $.account.accountId',
        account nvarchar(max) 'strict $.account.account' as json
        ) A
        cross apply openjson(A.account) with
        (
        identification varchar(100)
        ) B


        Result:



        enter image description here






        share|improve this answer













        You are on the right track, you just need to extract the nested json section with as json and then use another cross apply with open json to read the inner account section:



        declare @tmp table ([id] int, BankDataText nvarchar(max))
        declare @j nvarchar(max)='{
        "data": [{
        "account": {
        "account": [{
        "schemaName": "SortCodeAccountNumber",
        "identification": "99999829250103",
        "name": "Load testing ....",
        "secondaryIdentification": "123456789"
        }],
        "accountType": "null",
        "accountSubType": "null",
        "description": null,
        "accountId": "LOADACC001",
        "currency": "GBP",
        "nickname": "LoadTest",
        "servicer": {
        "schemaName": "BICFI",
        "identification": "PAPAUK00XXX"
        }
        }
        }]
        }'
        insert into @tmp select 675, @j

        select top 1
        A.accountId as NonUserAccountId, B.identification
        from @tmp t
        cross apply openjson (t.BankDataText, N'$.data') with
        (
        accountId varchar(100) 'strict $.account.accountId',
        account nvarchar(max) 'strict $.account.account' as json
        ) A
        cross apply openjson(A.account) with
        (
        identification varchar(100)
        ) B


        Result:



        enter image description here







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Jan 4 at 10:50









        AndreaAndrea

        7,751144854




        7,751144854
































            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54007182%2fusing-cross-apply-to-query-nested-arrays-in-json%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Monofisismo

            Angular Downloading a file using contenturl with Basic Authentication

            Olmecas