Non lo consiglierei davvero, ci sono modi molto migliori per farlo nel livello dell'applicazione, ma quanto segue evita i loop ed è molto meno dettagliato del tuo metodo attuale:
CREATE PROCEDURE dbo.GetJSON @ObjectName VARCHAR(255), @registries_per_request smallint = null
AS
BEGIN
IF OBJECT_ID(@ObjectName) IS NULL
BEGIN
SELECT Json = '';
RETURN
END;
DECLARE @Top NVARCHAR(20) = CASE WHEN @registries_per_request IS NOT NULL
THEN 'TOP (' + CAST(@registries_per_request AS NVARCHAR) + ') '
ELSE ''
END;
DECLARE @SQL NVARCHAR(MAX) = N'SELECT ' + @Top + '* INTO ##T ' +
'FROM ' + @ObjectName;
EXECUTE SP_EXECUTESQL @SQL;
DECLARE @X NVARCHAR(MAX) = '[' + (SELECT * FROM ##T FOR XML PATH('')) + ']';
SELECT @X = REPLACE(@X, '<' + Name + '>',
CASE WHEN ROW_NUMBER() OVER(ORDER BY Column_ID) = 1 THEN '{'
ELSE '' END + Name + ':'),
@X = REPLACE(@X, '</' + Name + '>', ','),
@X = REPLACE(@X, ',{', '}, {'),
@X = REPLACE(@X, ',]', '}]')
FROM sys.columns
WHERE [Object_ID] = OBJECT_ID(@ObjectName)
ORDER BY Column_ID;
DROP TABLE ##T;
SELECT Json = @X;
END
NB Ho cambiato il nome dell'oggetto in due parti (@schema e @table) per accettare solo il nome completo dell'oggetto.
L'idea è fondamentalmente di utilizzare l'estensione XML all'interno di SQL-Server per trasformare la tabella in XML, quindi sostituire semplicemente i tag di inizio con {ColumnName:
e i tag finali con ,
. Sono quindi necessarie altre due sostituzioni per interrompere l'aggiunta della parentesi di chiusura all'ultima colonna di ogni riga e rimuovere il ,
finale dalla stringa JSON.