Efficiently extract grid data for custom tables
In order to extract grid data to add it to custom tables, you would have to couple it with an actual form export with the grid.
Disclaimer: This information is subject to change
Example of getting individual grid cell values:
--@cashflow is a parameter passing in the grid question json data
--gridCellValues[0] references the first row of the grid
--‘$.”Qtr 1”’ references the column in the row
set @capy1q1=(select * from openjson(@cashflow,’$.gridCellValues[0]’) WITH(vcInvestCapitalY1Q1 varchar(15) ‘$.“Qtr 1”’))
set @capy1q2=(select * from openjson(@cashflow,’$.gridCellValues[0]’) WITH(vcInvestCapitalY1Q2 varchar(15) ‘$.“Qtr 2”’))
set @capy1q3=(select * from openjson(@cashflow,’$.gridCellValues[0]’) WITH(vcInvestCapitalY1Q3 varchar(15) ‘$.“Qtr 3”’))
set @capy1q4=(select * from openjson(@cashflow,’$.gridCellValues[0]’) WITH(vcInvestCapitalY1Q4 varchar(15) ‘$.“Qtr 4”’))
Example of returning all rows in the grid as separate rows in a sql select:
--inserts the grid rows into a custom table as separate rows/records
insert into tblInvestments(unqInstance_GUID,chInvestmentType,vcWBSCategoryCode,vcWBSCategoryName,intSortOrder,vcPercent,vcThisRequest,vcPriorRequests,vcFutureRequests)
select @isid,‘C’,* – ‘*’ is shorthand for the seven column values being extracted
--from the grid data via the OPENJSON call below
from OPENJSON(@invC,’$.gridCellValues’)
WITH(
vcWBSCategoryCode nchar(10) ‘$.“WBSCat”’,
vcWBSCategoryName varchar(50) ‘$.Investment’,
intSortOrder integer ‘$.“Sort Order”’,
vcPercent varchar(8) ‘$.Percent’,
vcThisRequest varchar(15) ‘$.“This Request”’,
vcPriorRequests varchar(15) ‘$.“Prior Requests”’,
vcFutureRequests varchar(15) ‘$.“Future Requests”’)