sql >> Database >  >> RDS >> Sqlserver

Hoe alle kolommen in een select samen te voegen met SQL Server

Een willekeurig aantal kolommen voor een bepaalde tabelnaam;Als je kolomnamen nodig hebt omwikkeld met <text>

DECLARE @s VARCHAR(500)

SELECT @s =  ISNULL(@s+', ','') + c.name   
FROM  sys.all_columns c join sys.tables  t 
            ON  c.object_id = t.object_id
WHERE t.name = 'YourTableName'

SELECT '<text>' + @s + '</text>'

SQL Fiddle Voorbeeld hier

-- RESULTS 
<text>col1, col2, col3,...</text>

Als u de zoekopdracht resultaatset verpakt wilt selecteren, met <text> dan;

SELECT @S =  ISNULL( @S+ ')' +'+'',''+ ','') + 'convert(varchar(50), ' + c.name    FROM 
       sys.all_columns c join sys.tables  t 
       ON  c.object_id = t.object_id
WHERE t.name = 'YourTableName'


EXEC( 'SELECT ''<text>''+' + @s + ')+' + '''</text>'' FROM YourTableName')

SQL Fiddle Voorbeeld hier

--RESULTS
<text>c1r1,c2r1,c3r1,...</text>
<text>c1r2,c2r2,c3r2,...</text>
<text>c1r3,c2r3,c3r3,...</text>


  1. Vereist LIMIT OFFSET,LENGTH ORDER BY voor paginering?

  2. Hoe maak je een functie vriend/vriend toevoegen in PHP?

  3. SQLite - ORDER OP RAND()

  4. MySQL-tabelnaam als parameter